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1.0 INTRODUCTION 



The term "microcomputer" has been used to describe virtually every type of small 
computing device designed within the last few years. This term has been applied to 
everything from simple "microprogrammed" controllers constructed out of TTL MSI up 
to low end minicomputers with a portion of the CPU constructed out of TTL LSI "bit 
slices." However, the major impact of the LSI technology within the last few years has been 
with MOS LSI. With this technology, it is possible to fabricate complete and very powerful 
computer systems with only a few MOS LSI components. 



The Mostek Z80 family of components is a significant advancement in the state-of-art of 
microcomputers. These components can be configured with any type of standard semi- 
conductor memory to generate computer systems with an extremely wide range of 
capabilities. For example, as few as two LSI circuits and three standard TTL MSI packages 
can be combined to form a simple controller. With additional memory and I/O devices a 
computer can be constructed with capabilities that only a minicomputer could previously 
deliver. This wide range of computational power allows standard modules to be constructed 
by a user that can satisfy the requirements of an extremely wide range of applications. 



The major reason for MOS LSI domination of the microcomputer market is the low cost of 
these few LSI components. For example, MOS LSI microcomputers have already replaced 
TTL logic in such applications as terminal controllers, peripheral device controllers, traffic 
signal controllers, point of sale terminals, intelligent terminals and test systems. In fact the 
MOS LSI microcomputer is finding its way into almost every product that now uses 
electronics and it is even replacing many mechanical systems such as weight scales and 
automobile controls. 



The MOS LSI microcomputer market is already well established and new products using 
them are being developed at an extraordinary rate. The Mostek Z80 component set has been 
designed to fit into this market through the following factors: 

1. The Z80 is fully software compatible with the popular 8080A CPU offered from 
several sources. Existing designs can be easily converted to include the Z80 as a 
superior alternative. 

2. The Z80 component set is superior in both software and hardware capabilities to 
any other 8-bit microcomputer system on the market. These capabilities provide the 
user with significantly lower hardware and software development costs while also 
allowing him to offer additional features in his system. 

3. A complete development and OEM system product line including full software 
support is available to enable the user to easily develop new products. 



Microcomputer systems are extremely simple to construct using Z80 components. Any such 
system consists of three parts: 

1. CPU (Central Processing Unit) 

2. Memory 

3. Interface circuits to peripheral devices 



The CPU is the heart of the system. Its function is to obtain instructions from the memory 
and perform the desired operations. The memory is used to contain instructions and in most 
cases data that is to be processed. For example, a typical instruction sequence may be to 
read data from a specific peripheral device, store it in a location in memory, check the 
parity and write it out to another peripheral device. Note that the Mostek component set 
includes the CPU and various general purpose I/O device controllers, as well as a wide range 
of memory devices. Thus, all required components can be connected together in a very 
simple manner with virtually no other external logic. The user's effort then becomes 
primarily one of software development. That is, the user can concentrate on describing his 
problem and translating it into a series of instructions that can be loaded into the micro- 
computer memory. Mostek is dedicated to making this step of software generation as simple 
as possible. A good example of this is our assembly language in which a simple mnemonic 
is used to represent every instruction that the CPU can perform. This language is self docu- 
menting in such a way that from the mnemonic the user can understand exactly what the 
instruction is doing without constantly checking back to a complex cross listing. 
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2.0 Z80-CPU ARCHITECHURE 



A block diagram of the internal architecture of the Z80-CPU is shown in Figure 2.0-1 
The diagram shows all of the major elements in the CPU and it should be referred to 
throughout the following description. 
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2.1 CPU REGISTERS 

The Z80-CPU contains 208 bits of R/W memory that are accessible to the programmer. 
Figure 2.0-2 illustrates how this memory is configured into eighteen 8-bit registers and 
four 16-bit registers. All Z80 registers are implemented using static RAM. The registers 
include two sets of six general purpose registers that may be used individually as 8-bit 
registers or in pairs as 16-bit registers. There are also two sets of accumulator and flag 
registers. 

Special Purpose Registers 

1. Program Counter (PC). The program counter holds the 16-bit address of the current 
instruction being fetched from memory. The PC is automatically incremented after 
its contents have been transferred to the address lines. When a program jump occurs 
the new value is automatically placed in the PC, overriding the incrementer. 

2. Stack Pointer (SP). The stack pointer holds the 16-bit address of the current top of 
a stack located anywhere in external system RAM memory. The external stack 
memory is organized as a last-in first-out (LIFO) file. Data can be pushed onto the 
stack from specific CPU registers or popped off of the stack into specific CPU regis- 
ters through the execution of PUSH and POP instructions. The data popped from the 
stack is always the last data pushed onto it. The stack allows simple implementation 
of multiple level interrupts, unlimited subroutine nesting and simplification of many 
types of data manipulation. 
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3. Two Index Registers (IX & IY). The two independent index registers hold a 16-bit 
base address that is used in indexed addressing modes. In this mode, an index register 
is used as a base to point to a region in memory from which data is to be stored or 
retrieved. An additional byte is included in indexed instructions to specify a dis- 
placement from this base. This displacement is specified as a two's complement 
signed integer. This mode of addressing greatly simplifies many types of programs, 
especially where tables of data are used. 

4. Interrupt Page Address Register (I). The Z80-CPU can be operated in a mode where 
an indirect call to any memory location can be achieved in response to an interrupt. 
The I Register is used for this purpose to store the high order 8-bits of the indirect 
address while the interrupting device provides the lower 8-bits of the address. This 
feature allows interrupt routines to be dynamically located anywhere in memory with 
absolute minimal access time to the routine. 

5. Memory Refresh Register (R). The Z80-CPU contains a memory refresh counter to 
enable dynamic memories to be used with the same ease as static memories. This 7-bit 
register is automatically incremented after each instruction fetch. The data in the 
refresh counter is sent out on the lower portion of the address bus along with a 
refresh control signal while the CPU is decoding and executing the fetched instruc- 
tion. This mode of refresh is totally transparent to the programmer and does not 
slow down the CPU operation. The programmer can load the R register for testing 
purposes, but this register is normally not used by the programmer. 



Accumulator and Flag Registers 

The CPU includes two independent 8-bit accumulators and associated 8-bit flag registers. 
The accumulator holds the results of 8-bit arithmetic or logical operations while the flag 
register indicates specific conditions for 8 or 16-bit operations, such as indicating whether 
or not the result of an operation is equal to zero. The programmer selects the accumulator 
and flag pair that he wishes to work with with a single exchange instruction so that he may 
easily work with either pair. 
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General Purpose Registers 



There are two matched sets of general purpose registers, each set containing six 8-bit regis- 
ters that may be used individually as 8-bit registers or as 16-bit register pairs by the prog- 
rammer. One set is called BC, DE, and HL while the complementary set is called BD', DE' 
and HL'. At any one time the programmer can select either set of registers to work with 
through a single exchange command for the entire set. In systems where fast interrupt 
response is required, one set of general purpose registers and an accumulator/flag register 
may be reserved for handling this very fast routine. Only a simple exchange command need 
be executed to go between the routines. This greatly reduces interrupt service time by 
eliminating the requirement for saving and retrieving register contents in the external 
stack during interrupt or subroutine processing. These general purpose registers are used for 
a wide range of applications by the programmer. They also simplify programming, especially 
in ROM based systems where little external read/write memory is available. 



2.2 ARITHMETIC & LOGIC UNIT (ALU) 

The 8-bit arithmetic and logical instructions of the CPU are executed in the ALU. Internally 
the ALU communicates with the registers and the external data bus on the internal data bus. 
The type of functions performed by the ALU include: 



Add Left or right shifts or rotates (arithmetic and logical) 

Subtract I ncrement 

Logical AND Decrement 

Logical OR Set bit 

Logical Exclusive OR Reset bit 

Compare Test bit 



2.3 INSTRUCTION REGISTER AND CPU CONTROL 

As each instruction is fetched from memory, it is placed in the instruction register and 
decoded. The control section performs this function and then generates and supplies all of 
the control signals necessary to read or write data from or to the registers, controls the 
ALU and provides all required external control signals. 
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3.0 Z80 CPU PIN DESCRIPTION 



The Z80-CPU is packaged in an industry standard 40 pin Dual In-Line Package. The I/O 
pins are shown in Figure 3.0-1 and the function of each is described below. 
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A 0'A15 
(Address Bus) 



Tri-state output, active high. Aq-A-js constitute a 16-bit address 
bus. The address bus provides the address for memory (up to 64K 
bytes) data exchanges and for I/O device data exchanges. I/O 
addressing uses the 8 lower address bits to allow the user to 
directly select up to 256 input or 256 output ports. Aq is the 
least significant address bit. During refresh time, the lower 7 bits 
contain a valid refresh address. 



D -D 7 
(Data Bus) 



Mi 

(Machine Cycle one) 



Tri-state input/output, active high. D0-D7 constitute an 8-bit 
bidirectional data bus. The data bus is used for data exchanges 
with memory and I/O devices. 

Output, active low. M-| indicates that the current machine cycle 
is the OP code fetch cycle of an instruction execution. Note that 
during execution of 2-byte op-codes, M] is generated as each op 
code byte is fetched. These two byte op-codes always begin with 
CBH, DDH, EDH, or FDH. M-j also occurs with IORQ to indicate 
an interrupt acknowledge cycle. 



MREQ 

(Memory Request) 



Tri-state output, active low. The memory request signal indicates 
that the address bus holds a valid address for a memory read or 
memory write operation. 
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IORQ 

(Input/Output Request) 



Tri-state output, active low. The IORQ signal indicates that the 
lower half of the address bu s holds a valid I/O address for a I/O 
read or write operation. An IORQ signal is also generated with 
an M-| signal when an interrupt is being acknowledged to indicate 
that an interrupt response vector can be placed on the data bus. 
Interrupt Acknowledge operations occur during M-| time while 
I/O operations never occur during M<| time. 



RD 

(Memory Read) 



Tri-state output, active low. RD indicates that the CPU wants to 
read data from memory or an I/O device. The addressed I/O device 
or memory should use this signal to gate data onto the CPU data 
bus. 



WR 

(Memory Write) 



Tri-state output, active low. WR indicates that the CPU data bus 
holds valid data to be stored in the addressed memory or I/O 
device. 



RFSH 
(Refresh) 



Output, active low. RFSH indicates that the lower 7 bits of the 
address bus co ntain a refresh address for dynamic memories and 
current MREQ signal should be used to do a refresh read to all 
dynamic memories. A7 is a logic zero and the upper 8 bits of the 
Address Bus contains the I Register. 



HALT 
(Halt state) 



Output, active low. HALT indicates that the CPU has executed a 
HALT software instruction and is awaiting either a non maskable 
or a maskable interrupt (with the mask enabled) before operation 
can resume. While halted, the CPU executes NOP's to maintain 
memory refresh activity. 



WAIT* 
(Wait) 



Input, active low. WAIT indicates to the Z80-CPU that the add- 
ressed memory or I/O devices are not ready for a data transfer. 
The CPU continues to enter wait states for as long as this signal is 
active. This signal allows memory or I/O devices of any speed to 
be synchronized to the CPU. 



INT 

(Interrupt Request) 



Input, active low. The Interrupt Request signal is generated by 
I/O devices, A request will be honored at the end of the current 
instruction if the internal software control led interrupt enable 
flip-flop (IFF) is enabled and if the BUSRQ signal is not active. 
When the CPU accepts the interrupt, an acknowledge signal 
(IORQ during M-| time) is sent out at the beginning of the next 
instruction cycle. The CPU can respond to an interrupt in three 
different modes that are described in detail in section 8. 



NMI 



Input, negative edge triggered. The non maskable interrupt request 
line has a higher priority than INT and is always recognized at the 
end of the current instru ction , independent of the status of the 
interrupt enable flip-flop. NMI automatically forces the Z80-CPU 
to restart to location 0066|_|. The program counter is automati- 
cally saved in the external stack so that the user can return to the 
program that was interrupted. Note that continuous WAIT cycles 
can pre vent the curr ent instruction from ending, and that a 
BUSRQ will override a NMI. 
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RESET 



Input, active low. RESET forces the program counter to zero and 
initializes the CPU. The CPU initialization includes: 



1) Disable the interrupt enable flip-flop 

2) Set Register I = 00h 

3) Set Register R = 00h 

4) Set Interrupt Mode 

During reset time, the address bus and data bus go to a high 
impedance state and all control output signals go to the inactive 
state. No refresh occurs. 



BUSRQ 
(Bus Request) 



BUSAK* 

(Bus Acknowledge) 



Input, active low. The bus request signal is used to request the 
CPU address bus, data bus and tri-state output control signals to 
go to a high impe dance sta te so that other devices can control 
these buses. When BUSRQ is activated, the CPU will set these 
buses to a high impedance state as soon as the current CPU 
machine cycle is terminated. 

Output, active low. Bus acknowledge is used to indicate to the 
requesting device that the CPU address bus, data bus and tri- 
state control bus signals have been set to their high impedance 
state and the external device can now control these signals. 



Single phase system clock. 



*While the Z80-CPU is in either a WAIT state or a Bus Acknowledge condition, Dynamic Memory Refresh 
will not occur. 
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4.0 CPU TIMING 



The Z80-CPU executes instructions by stepping through a very precise set of a few basic 
operations. These include: 

Memory read or write 

I/O device read or write 

Interrupt acknowledge 

All instructions are merely a series of these basic operations. Each of these basic operations 
can take from three to six clock periods to complete or they can be lengthened to syn- 
chronize the CPU to the speed of external devices. The basic clock periods are referred to as 
T states and the basic operations are referred to as M (for machine) cycles. Figure 4.0-0 
illustrates how a typical instruction will be merely a series of specific M and T cycles. Notice 
that this instruction consists of three machine cycles (M1, M2 and M3). The first machine 
cycle of any instruction is a fetch cycle which is four, five or six T states long (unless 
lengthened by the wait signal which will be fully described in the next section). The fetch 
cycle (M1) is used to fetch the OP code of the next instruction to be executed. Subsequent 
machine cycles move data between the CPU and memory or I/O devices and they may have 
anywhere from three to five T cycles (again they may be lengthened by wait states to 
synchronize the external devices to the CPU). The following paragraphs describe the timing 
which occurs within any of the basic machine cycles. In section 7, the exact timing for 
each instruction is specified. 



BASIC CPU TIMING EXAMPLE 
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FIGURE 4.0-0 



All CPU timing can be broken down into a few very simple timing diagrams as shown in 

Figure 4.0-1 through 4.0-7. These diagrams show the following basic operations with and 

without wait states (wait states are added to synchronize the CPU to slow memory or 
I/O devices). 

4.0-1. Instruction OP code fetch (M1 cycle) 

4.0-2. Memory data read or write cycles 

4.0-3. I/O read or write cycles 

4.0-4. Bus Request/ Acknowledge Cycle 

4.0-5. Interrupt Request/ Acknowledge Cycle 

4.0-6. Non maskable Interrupt Request/Acknowledge Cycle 

4.0-7. Exit from a HALT instruction 
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INSTRUCTION FETCH 



Figure 4.0-1 shows the timing during an M1 cycle (OP code fetch). Notice that the PC is 
placed on the address bus at the beginning of the M1 cycle. One half clock time later the 
MREQ signal goes active. A t this t ime the address to the memory has had time to stabilize 
so that the falling edge of MREQ can be used directly as a chip enable clock to dynamic 
memories. The RD line also goes active to indicate that the memory read data should be 
enabled onto the CPU data bus. The CPU samples the data from the memory on the data 
bus with the rising edg e of th e clock of state T3 and this same edge is used by the CPU 
to turn off the RD and MREQ signals. Thus the data has already been sampled by the CPU 
before the RD signal becomes inactive. Clock state T3 and T4 of a fetch cycle are used to 
refresh dynamic memories. (The CPU uses this time to decode and execute the fetched 
instruction so that no other operation could be performed at this time). Durin g T3 a nd T4 
the lower 7 bits of the address bus contain a memory refresh address and the RFSH signal 
becomes active to indicate that a refresh read of all dynamic memories should be accom- 
plished. Notice that a RD signal is not generated during refresh time t o preve nt data from 
different memory segments from being gated onto the data bus. The MREQ signal during 
refresh time should be used to perform a refresh read of all memory elements. The refresh 
signal can no t be used by itself since the refresh address is only guaranteed to be stable 
during MREQ time. 



INSTRUCTION OP CODE FETCH 
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Figure 4.0-1A illustrates how the fetch cycle is delayed if the memory activates the WAIT 
line. During T2 a nd eve ry subsequent Tw, the CPU samples the WAIT line with the falling 
edge of If the WAIT line is active at this time, another wait state will be entered during 
the following cycle. Using this technique the read cycle can be lengthened to match the 
access time of any type of memory device. 



INSTRUCTION OP CODE FETCH WITH WAIT STATES 
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MEMORY READ OR WRITE 



Figure 4.0-2 illustrates the timing of memory read or write cycles other than an OP code 
fetch (M1 cycle). These cycles ar e gene rally three clock p eriods long unless wait states are 
requested by the memory via the WAIT signal. The MREQ signal and t he RD s ignal are used 
the same as in the fetch cycle. In the case of a memory write cycle, the MREQ also becomes 
active when the address bus is stable so that it can be used directly as a chip enable for 
dynamic memories. The WR line is active when data on the data bus is stable so that it can 
be used d irec tly as a R/W pulse to virtually any type of semiconductor memory. Further- 
more the WR signal goes inactive one half T state before the address and data bus contents 
are changed so that the overlap requirements for virtually any type of semiconductor 
memory type will be met. 



MEMORY READ OR WRITE CYCLES 
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Figure 4.0-2A illustrates how a WAIT request signal will lengthen any memory read or 
write operation. This operation is identical to that previously described for a fetch cycle. 
Notice in this figure that a separate read and a separate write cycle are shown in the same 
figure although read and write cycles can never occur simultaneously. 



MEMORY READ OR WRITE CYCLES WITH WAIT STATES 
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INPUT OR OUTPUT CYCLES 

Figure 4.0-3 illustrates an I/O read or I/O write operation. Notice that during I/O operations 
a single wait state is auto matica lly inserted. The reason for this is that during I/O operati ons, 
the time from when the IORQ signal goes active until the CPU must sample the WAIT line 
is very short and without this extr a state sufficient time does not exist for an I/O port to 
decode its address and activate the WAIT line if a wait is required. Also, without this wait 
state it is difficult to de sign M PS I/O devices that can operate at full CPU speed. During 
this wait state time the WAIT request signal is sampled. During a read I/O operation, the 
RD line is used to enable the addressed port onto the data bus just as in the case of a 
memory read. For I/O write operations, the WR line is used as a clock to the I/O port, again 
with sufficient overlap timing automatically provided so that the rising edge may be used as 
a data clock. 



Figure 4.0-3A illustrates how additional wait states may be added with the WAIT line. 
The operation is identical to that previously described. 



BUS REQUEST/ ACKNOWLEDGE CYCLE 



Figure 4.0-4 illustrates the timing for a Bus Request/ Acknowledge cycle. The BUSRQ 
signal is sam pled by the CPU with the rising edge of the last clock period of any machine 
cycle. If the BUSRQ signal is active, the CPU will set its address, data and tri-state control 
signals to the high impedance state with the rising edge of the next clock pulse. At that 
time any external device can control the buses to transfer data between memory and I/O 
devices. (This is generally known as Direct Memory Access [DMA] using cycle stealing). 
The maximum time for the CPU to respond to a bus request is the length of a machine 
cycle and the external controller can maintain control of the bus for as many clock cycles 
as is desired. Note, however, that if very long DMA cycles are used, and dynamic memories 
are being used, the external controller must also perform the refresh function. This situation 
only occurs if very large blocks of data are transferred under DMA c ontro l. Als o not e that 
during a bus request cycle, the CPU cannot be interrupted by either a NMI or an INT signal. 
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INPUT OR OUTPUT CYCLES 
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INPUT OR OUTPUT CYCLES WITH WAIT STATES 
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INPUT OR OUTPUT CYCLES 
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INPUT OR OUTPUT CYCLES WITH WAIT STATES 
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BUS REQUEST/ACKNOWLEDGE CYCLE 
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INTERRUPT REQUEST/ ACKNOWLEDGE CYCLE 

Figure 4.0-5 illustrates the tinning associated with an interrupt cycle. The interrupt signal 
(TNT) is sampled by the CPU with the rising edge of the last clock at the end of any in- 
struction. The signal will not be acc epted if the internal CPU software controlled interrupt 
enable flip-flop is not set or if the BUSRQ signal is active. Wh en th e signal is accepted a 
special M1 cycle is gene rated. During this special M1 cycle the IORQ signal becomes active 
(instead of the normal MREQ) to indicate that the interrupting device can place an 8-bit 
vector on the data bus. Notice that two wait states are automatically added to this cycle. 
These states are added so that a ripple priority interrupt scheme can be easily implemented. 
The two wait states allow sufficient time for the ripple signals to stablilize and identify 
which I/O device must insert the response vector. Refer to section 8.0 for details on how the 
interrupt response vector is utilized by the CPU. 



INTERRUPT REQUEST/ACKNOWLEDGE CYCLE 
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Figure 4.0-5A illustrates how additional wait states can be added to the interrupt response 
cycle. Again the operation is identical to that previously described. 



INTERRUPT REQUEST/ACKNOWLEDGE WITH WAIT STATES 




RD | 

Mode shown 

FIGURE 4.0-5A 



NON MASKABLE INTERRUPT RESPONSE 

Figure 4.0-6 ill ustra tes the request/acknowledge cycle for the non-maskable interrupt. 
A pulse on the *NMl input sets an internal IMMI latch which is tested by the CPU at the 
end of every instruction. This NMI latch is sampled at the same time as the interrupt line, 
but this line has priority over the normal interrupt and it can not be disabled under soft- 
ware control. Its usual function is to provide immediate response to important signals 
such as an impending power failure. The CPU response to a non maskable interrupt is 
similar to a normal memory read operation. The only difference being that the content 
of the data bus is ignored while the processor automatically stores the PC in the external 
stack and jumps to location 0066H- The service routine for the non maskable interrupt 
must begin at this location if this interrupt is used. 

HALT EXIT 

Whenever a software halt instruction is executed the CPU begins executing NOP's until an 
interrupt is received (either a non-maskable or a maskable interrupt while the interrupt 
flip flop is enabled). The two interrupt lines are sampled with the rising clock edge during 
each T4 state as shown in Figure 4.0-7. If a non-maskable interrupt has been received or a 
maskable interrupt has been received and the interrupt enable flip-flop is set, then the halt 
state will be exited on the next rising clock edge. The following cycle will then be an inter- 
rupt acknowledge cycle corresponding to the type of interrupt that was received. If both are 
received at this time, then the non maskable one will be acknowledged since it was highest 
priority. The purpose of executing NOP instructions while in the halt state is to keep the 
memory refresh signals active. Each cycle in the halt state is a normal M1 (fetch) cycle 
except that the data received from the memory is ignored and a NOP instruction is forced 
internally to the CPU. The halt acknowledge signal is active during this time to indicate 
that the processor is in the halt state. 
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NON MASKABLE INTERRUPT REQUEST OPERATION 
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5.0 Z80-CPU INSTRUCTION SET 



The Z80-CPU can execute 158 different instruction types including all 78 of the 8080A 
CPU. The instructions can be broken down into the following major groups: 

° Load and Exchange 

• Block Transfer and Search 

• Arithmetic and Logical 

• Rotate and Shift 

- Bit Manipulation (set, reset, test) 

• Jump, Call and Return 

• Input/Output 

- Basic CPU Control 



5.1 INTRODUCTION TO INSTRUCTION TYPES 



The load instructions move data internally between CPU registers or between CPU registers 
and external memory. All of these instructions must specify a source location from which 
the data is to be moved and a destination location. The source location is not altered by 
a load instruction. Examples of load group instructions include moves between any of the 
general purpose registers such as move the data to Register B from Register C. This group 
also includes load immediate to any CPU register or to any external memory location. 
Other types of load instructions allow transfer between CPU registers and memory locations. 
The exchange instructions can trade the contents of two registers. 

A unique set of block transfer instructions is provided in the Z80. With a single instruction a 
block of memory of any size can be moved to any other location in memory. This set of 
block moves is extremely valuable when large strings of data must be processed. The Z80 
block search instructions are also valuable for this type of processing. With a single 
instruction, a block of external memory of any desired length can be searched for any 8-bit 
character. Once the character is found the instruction automatically terminates. Both the 
block transfer and the block search instructions can be interrupted during their execution so 
as to not occupy the CPU for long periods of time. 

The arithmetic and logical instructions operate on data stored in the accumulator and other 
general purpose CPU registers or external memory locations. The results of the operations 
are placed in the accumulator and the appropriate flags are set according to the result of 
the operation. An example of an arithmetic operation is adding the accumulator to the con- 
tents of an external memory location. The results of the addition are placed in the 
accumulator. This group also includes 16-bit addition and subtraction between 16-bit CPU 
registers. 

The bit manipulation instructions allow any bit in the accumulator, any general purpose 
register or any external memory location to be set, reset or tested with a single instruction. 
For example, the most significant bit of register H can be reset. This group is especially 
useful in control applications and for controlling software flags in general purpose prog- 
ramming. 

The jump, call and return instructions are used to transfer between various locations in the 
user's program. This group uses several different techniques for obtaining the new program 
counter address from specific external memory locations. A unique type of jump is the 
restart instruction. This instruction actually contains the new address as a part of the 8-bit 
OP code. This is possible since only 8 separate addresses located in page zero of the external 
memory may be specified. Program jumps may also be achieved by loading register HL, IX 
or IY directly into the PC, thus allowing the jump address to be a complex function of the 
routine being executed. 



The input/output group of instructions in the Z80 allow for a wide range of transfers 
between external memory locations or the general purpose CPU registers, and the external 
I/O devices. In each case, the port number is provided on the lower 8 bits of the address 
bus during any I/O transaction. One instruction allows this port number to be specified by 
the second byte of the instruction while other Z80 instructions allow it to be specified 
as the content of the C register. One major advantage of using the C register as a pointer to 
the I/O device is that it allows different I/O ports to share common software driver routines. 
This is not possible when the address is part of the OP code if the routines are stored in 
ROM. Another feature of these input instructions is that they set the flag register automati- 
cally so that additional operations are not required to determine the state of the input data 
(for example its parity). The Z80-CPU includes single instructions that can move blocks or 
data (up to 256 bytes) automatically to or from any I/O port directly to any memory 
location. In conjunction with the dual set of general purpose registers, these instructions 
provide for fast I/O block transfer rates. The value of this I/O instruction set is demon- 
strated by the fact that the Z80-CPU can provide all required floppy disk formatting (i.e., 
the CPU provides the preamble, address, data and enables the CRC codes) on double density 
floppy disk drives on an interrupt driven basis. 

Finally, the basic CPU control instructions allow various options and modes. This group 
includes instructions such as setting or resetting the interrupt enable flip flop or setting 
the mode of interrupt response. 



5.2 ADDRESSING MODES 



Most of the Z80 instructions operate on data stored in internal CPU registers, external 
memory or in the I/O ports. Addressing refers to how the address of this data is generated 
in each instruction. This section gives a brief summary of the types of addressing used 
in the Z80 while subsequent sections detail the type of addressing available for each in- 
struction group. 

Immediate. In this mode of addressing the byte following the OP code in memory contains 
the actual operand. 



d 7 



OP Code 



Operand 



^one or 2 bytes 



d 



Examples of this type of instruction would be to load the accumulator with a constant, 
where the constant is the byte immediately following the OP code. 

Immediate Extended. This mode is merely an extension of immediate addressing in that the 
two bytes following the op codes are the operand. 



OP Code 



Operand 



Operand 



one or 2 bytes 
low order 
high order 



Examples of this type of instruction would be to load the HL register pair (16-bit register) 
with 16 bits (2 bytes) of data. 



Modified Page Zero Addressing. The Z80 has a special single byte call instruction to any of 
8 locations in page zero of memory. This instruction (which is referred to as a restart) sets 
the PC to an effective address in page zero. The value of this instruction is that it allows a 
single byte to specify a complete 16-bit address where commonly called subroutines are 
located, thus saving memory space. 



OP Code one byte 



b 7 



bQ Effective address is (00b5b4b3000) 



Relative Addressing. Relative addressing uses one byte of data following the OP code to 
specify a displacement from the existing program to which a program jump can occur. 
This displacement is a signed two's complement number that is added to the address of the 
OP code of the following instruction. 



OP Code 



Operand 



Jump relative (one byte OP code) 

8-bit two's complement displacement added to 
Address (A+2) 



The value of relative addressing is that it allows jumps to nearby locations while only 
requiring two bytes of memory space. For most programs, relative jumps are by far the 
most prevalent type of jump due to the proximity of related program segments. Thus, 
these instructions can significantly reduce memory space requirements. The signed dis- 
placement can range between +127 and -128 from A + 2. This allows for a total displace- 
ment of +129 to -126 from the jump relative OP code address. Another major advantage 
is that it allows for relocatable code. 

Extended Addressing. Extended Addressing provides for two bytes (16 bits) of address to 
be included in the instruction. This data can be an address to which a program can jump or 
it can be an address where an operand is located. 



OP Code 



Low Order Address or Low order operand 



High Order Address or High order operand 



^ one or two bytes 



Extended addressing is required for a program to jump from any location in memory to any 
other location, or load and store data in any memory location. 

When extended addressing is used to specify the source or destination address of an operand, 
the notation (nn) will be used to indicate the content of memory at nn, where nn is the 
16-bit address specified in the instruction. This means that the two bytes of address nn are 
used as a pointer to a memory location. The use of the parentheses always means that the 
value enclosed within them is used as a pointer to a memory location. For example, (1200) 
refers to the contents of memory at location 1200. 

Indexed Addressing. In this type of addressing, the byte of data following the OP code 
contains a displacement which is added to one of the two index registers (the OP code 
specifies which index register is used) to form a pointer to memory. The contents of the 
index register are not altered by this operation. 



OP Code 



OP Code 



Displacement 



two byte OP code 



Operand added to index register to form a pointer 
to memory. 



An example of an indexed instruction would be to load the contents of the memory loca- 
tion (Index Register + Displacement) into the accumulator. The displacement is a signed 
two's complement number. Indexed addressing greatly simplifies programs using tables of 
data since the index register can point to the start of any table. Two index registers are 
provided since very often operations require two or more tables. Indexed addressing also 
allows for relocatable code. 



The two index registers in the Z80 are referred to as IX and IY. To indicate indexed add- 
ressing the notation: 

(IX+d) or (lY+d) 

is used, here d is the displacement specified after the OP code. The parentheses indicate that 
this value is used as a pointer to external memory. 

Register Addressing. Many of the Z80 OP codes contain bits of information that specify 
which CPU register is to be used for an operation. An example of register addressing would 
be to load the data in register B into register C. 

Implied Addressing. Implied addressing refers to operations where the OP code automati- 
cally implies one or more CPU registers as containing the operands. An example is the set of 
arithmetic operations where the accumulator is always implied to be the destination of the 
results. 



Register Indirect Addressing. This type of addressing specifies a 16-bit CPU register pair 
(such as HL) to be used as a pointer to any location in memory. This type of instruction is 
very powerful and it is used in a wide range of applications. 



OP Code 



^ one or two bytes 



An example of this type of instruction would be to load the accumulator with the data in 
the memory location pointed to by the HL register contents. Indexed addressing is actually 
a form of register indirect addressing except that a displacement is added with indexed 
addressing. Register indirect addressing allows for very powerful but simple to implement 
memory accesses. The block move and search commands in the Z80 are extensions of this 
type of addressing where automatic register incrementing, decrementing and comparing 
has been added. The notation for indicating register indirect addressing is to put paren- 
theses around the name of the register that is to be used as the pointer. For example, the 
symbol 



(HL) 



specifies that the contents of the HL register are to be used as a pointer to a memory 
location. Often register indirect addressing is used to specify 16-bit operands. In this case, 
the register contents point to the lower order portion of the operand while the register 
contents are automatically incremented to obtain the upper portion of the operand. 

Bit Addressing. The Z80 contains a large number of bit set, reset and test instructions. 
These instructions allow any memory location or CPU register to be specified for a bit 
operation through one of three previous addressing modes (register, register indirect and 
indexed) while three bits in the OP code specify which of the eight bits is to be manipulated. 



ADDRESSING MODE COMBINATIONS 

Many instructions include more than one operand (such as arithmetic instructions or loads). 
In these cases, two types of addressing may be employed. For example, load can use im- 
mediate addressing to specify the source and register indirect or indexed addressing to 
specify the source and register indirect or indexed addressing to specify the destination. 



5.3 INSTRUCTION OP CODES 



This section describes each of the Z80 instructions and provides tables listing the OP codes 
for every instruction. In each of these tables the shaded OP codes are identical to those 
offered in the 8080A CPU. Also shown is the assembly language mnemonic that is used for 
each instruction. All instruction OP codes are listed in hexadecimal notation. Single byte 
OP codes require two hex characters while double byte OP codes require four hex characters. 
The conversion from hex to binary is repeated here for convenience. 
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Z80 instruction mnemonics consist of an OP code and zero, one or two operands. 
Instructions in which the operand is implied have no operand. Instructions which have 
only one logical operand or those in which one operand is invariant (such as the Logical OR 
instruction) are represented by a one operand mnemonic. Instructions which may have 
two varying operands are represented by two operand mnemonics. 

LOAD AND EXCHANGE 

Table 5.3-1 defines the OP code for all of the 8-bit load instructions implemented in the 
Z80-CPU. Also shown in this table is the type of addressing used for each instruction. The 
source of the data is found on the top horizontal row while the destination is specified by 
the left hand column. For example, load register C from register B uses the OP code 48H. 
in all of the tables the OP code is specified in hexadecimal notation and the 48H (=0100 
1000 binary) code is fetched by the CPU from the external memory during M1 time, 
decoded and then the register transfer is automatically performed by the CPU. 

The assembly language mnemonic for this entire group is LD, followed by the destination 
followed by the source (LD DEST., SOURCE). Note that several combinations of addressing 
modes are possible. For example, the source may use register addressing and the destination 
may be register indirect, such as load the memory location pointed to by register HLwith 
the contents of register D. The OP code for this operation would be 72. The mnemonic for 
this load instruction would be as follows: LD (HL), D 

The parentheses around the HL means that the contents of HL are used as a pointer to a 
memory location. In all Z80 load instruction mnemonics the destination is always listed 
first, with the source following. The Z80 assembly language has been defined for ease of 
programming. Every instruction is self documenting and programs written in Z80 language 
are easy to maintain. 

Note in Table 5.3-1 that some load OP codes that are available in the Z80 use two bytes. 
This is an efficient method of memory utilization since 8, 16, 24 or 32 bit instructions 
are implemented in the Z80. Thus often utilized instructions such as arithmetic or logical 
operations are only 8-bits which results in better memory utilization than is achieved with 
fixed instruction sizes such as 16-bits. 

All load instructions using indexed addressing for either the source or destination location 
actually use three bytes of memory with the third byte being the displacement d. For 
example a load register E with the operand pointed to by IX with an offset of +8 would be 
written: LD E, (IX + 8) 



The POP instruction is the exact reverse of a PUSH. Notice that all PUSH and POP instruc- 
tions utilize a 16-bit operand and the high order byte is always pushed first and popped last. 
That is a: 



PUSH BC is PUSH B then C 

PUSH DE is PUSH D then E 

PUSH HL is PUSH H then L 

POP HL is POP Lthen H 

The instruction using extended immediate addressing for the source obviously requires 
2 bytes of data following the OP code. For example: 

LD DE, 0659H 



will be: 



Address A 

A+1 
A+2 



11 



59 



06 



OP Code 

Low order operand to register E 
High order operand to register D 



in all extended immediate or extended addressing modes, the low order byte always appears 
first after the OP code. 

Table 5.3-3 lists the 16-bit exchange instructions implemented in the Z80. OP code 08H 
allows the programmer to switch between the two pairs of accumulator flag registers while 
D9H allows the programmer to switch between the duplicate set of six general purpose 
registers. These OP codes are only one byte in length to absolutely minimize the time 
necessary to perform the exchange so that the duplicate banks can be used to effect very 
fast interrupt response times. 



BLOCK TRANSFER AND SEARCH 

Table 5.3-4 lists the extremely powerful block transfer instructions. All of these instructions 
operate with three registers. 

HL points to the source location. 
DE points to the destination location. 
BC is a byte counter. 

After the programmer has initialized these three registers, any of these four instructions may 
be used. The LDI (Load and Increment) instruction moves one byte from the location 
pointed to by HL to the location pointed to by DE. Register pairs HL and DE are then 
automatically incremented and are ready to point to the following locations. The byte 
counter (register pair BC) is also decremented at this time. This instruction is valuable when 
blocks of data must be moved but other types of processing are required between each 
move. The LDI R (Load, increment and repeat) instruction is an extension of the LDI 
instruction. The same load and increment operation is repeated until the byte counter 
reaches the count of zero. Thus, this single instruction can move any block of data from one 
location to any other. 

Note that since 16-bit registers are used, the size of the block can be up to 64K bytes 
(1 K = 1024) long and it can be moved from any location in memory to any other location. 
Furthermore the blocks can be overlapping since there are absolutely no constraints on the 
data that is used in the three register pair. 

The LDD and LDDR instructions are very similar to the LDI and LDI R. The only difference 
is that register pairs HL and DE are decremented after every move so that a block transfer 
starts from the highest address of the designated block rather than the lowest. 



16 BIT LOAD GROUP 'LD' TUSH' AND 'POP' 



SOURCE 



DESTINATION 



PUSH 

INSTRUCTIONS 





REGISTER 


IMM. 
EXT. 


EXT. 
ADDR. 


REG. 
INDIR. 


AF 


BC 


DE 


HL 


SP 


IX 


IY 


nn 


(nn) 


(SP) 


R 
E 
G 

S 
T 
E 
R 


AF 




















F1 


BC 
















01 

n 
n 


ED 
4B 
n 
n 


C1 


DE 
















11 

n 

n 


ED 
5B 
n 
n 


01 


HL 
















21 

n 

n 


2A 

n 

n 


E1 


SP 








F9 




DD 
F9 


FD 
F9 


31 

n 

n 


ED 
7B 

n 
n 




IX 
















DD 
21 

n 
n 


DD 
2A 

n 
n 


DD 
E1 


IY 
















FD 

21 
n 
n 


FD 

n 
n 


ru 

El 


EXT. 
ADDR. 


(nn) 




ED 
43 

n 
n 


ED 
53 

n 
n 


22 

n 

n 


ED 
73 
n 
n 


DD 
22 
n 
n 


FD 
22 

n 
n 








REG. 
IND. 


(SP) 


F5 


C5 


05 


£5 




DD 
E5 


FD 
E5 









t 

NOTE: The Push & Pop Instructions adjust POP 

the SP after every execution INSTRUCTIONS 



TABLE 5.3-2 



EXCHANGES 'EX' AND 'EXX' 







IMPLIED ADDRESSING 






af' 


8C , DE'& Hl' 


HL 


IX 


IY 




AF 


08 










IMPLIED 


BC, 
DE 
& 
HL 




D9 










DE 






EB 






REG. 
INDIR. 


(SP) 






£3 


DD 
E3 


FD 
E3 



TABLE 5.3-3 



31 



8 BIT ARITHMETIC AND LOGIC 



SOURCE 





REGISTER ADDRESSING 


REG. 
INDIR. 


INDEXED 


IMMED. 


A 


B 


C 


D 


t 


H 


L 


(HI 1 


(IX+d) 


UY+d) 




'Ann' 


Of 

O/ 




Or 


82 


■ ■ ;.. :: OOI ■ ■.■ 


84 


85 


86 


DD 
d 


FD 

OD 

d 


C6 
n 


Ann uu paddv 

MUU W IrAnh T 

'ADC 


op 
or 


oo 


89 


8A 


8B 


8C 


8D 


8E 


DD 
8E 
d 


FD 
8E 
d 


n 


CI IRTHAPT 

SUB* 


3/ 


90 


3 1 


92 




94 


OR 

■ . ■■3f5J, :■ 




DD 
96 
d 


FD 
96 
d 


D6 
n 


<!IJB w PARRY 
'SBC 


■ OCT-:-- 






■■■■:9M-.; 


QD 


op 






DD 
9E 
d 


FD 
9E 
d 


DE 

n 


'AND' 


A7 


AO 


A1 


■ Af> 


; A3 


A4 


A5 


MO 


DD 
A6 
d 


FD 

Aft 
AD 

d 


£6 
n 


'XOR' 


AF 


A8 


A9 


AA 


AB 


AC 


AD 


V AE ' 


DD 
AE 

d 


FD 
AE 
d 


EE 
n 




Of 


DU 


■ P i 


B2 


B3 


D*+ 


DO 


B6 


DD 
B6 
d 


FD 
B6 
d 


ro 

n 


COMPARE 
'CP' 




B8 


B9 


8A 


BB 


BC 


BD 


DC .. 


DD 
BE 
d 


FD 
BE 
d 


■■ FE 
n 


INCREMENT 
'INC 


3C 


04 


OC 


14 


1C 


24 


2C 


34 


DD 
34 
d 


FD 
34 
d 




DECREMENT 
'DEC 


3D 


05 


00 


15 


ID 


25 


2D 


35 


DD 
35 
d 


FD 
35 
d 





TABLE 5.3-6 



GENERAL PURPOSE AF OPERATIONS 



Decimal Adjust Acc, 'DAA' 


27 


Complement Acc, 'CPL' 


2F 


Negate Acc, 'NEC 
(2's complement) 


ED 
44 


Complement Carry Flag, 'CCF' 


3F 


Set Carry Flag, 'SCF' 


37 



TABLE 5.3-7 



34 



16 BIT ARITHMETIC S0URCE 



DESTINATION 



TABLE 5.3-8 





BC 


DE 


HL 


SP 


IX 


IY 




HL 


09 


19 


29 


39 






'ADD' 


IX 


DD 


DD 




DD 


DD 








09 


19 




39 


29 






IY 


FD 


FD 




FD 




FD 






09 


19 




39 




29 


ADD WITH CARRY AND 


HL 


ED 


ED 


ED 


ED 






SET FLAGS 'ADC 




4A 


5A 


6A 


7A 






SUB WITH CARRY AND 


HL 


ED 


ED 


ED 


ED 






SET FLAGS 'SBC 




HZ 




62 


72 






INCREMENT 'INC. 


03 




23 


33 


DD 


FD 














23 


23 


DECREMENT 'DEC 


OB 


1B 


2B 


3B 


DD 


FD 














2B 


2B 



ROTATE AND SHIFT 

A major capability of the Z80 is its ability to rotate or shift data in the accumulator, any 
general purpose register, or any memory location. All of the rotate and shift OP codes are 
shown in Table 5.3-9. Also included in the Z80 are arithmetic and logical shift operations. 
These operations are useful in an extremely wide range of applications including integer 
multiplication and division. Two BCD digit rotate instructions (RRD and RLD) allow a digit 
in the accumulator to be rotated with the two digits in a memory location pointed to by 
register pair HL. (See Figure 5.3-9). These instructions allow for efficient BCD arithmetic. 

BIT MANIPULATION 

The ability to set, reset and test individual bits in a register or memory location is needed 
in almost every program. These bits may be flags in a general purpose software routine, 
indications of external control conditions or data packed into memory locations to make 
memory utilization more efficient. 



The Z80 has the ability to set, reset or test any bit in the accumulator, any general purpose 
register or any memory location with a single instruction. Table 5.3-10 lists the 240 instruc- 
tions that are available for this purpose. Register addressing can specify the accumulator or 
any general purpose register on which the operation is to be performed. Register indirect and 
indexed addressing are available to operate on external memory locations. Bit test operations 
set the zero flag (Z) if the tested bit is a zero. (Refer to section 6.0 for further explanation 
of flag operation). 

JUMP, CALL AND RETURN 

Figure 5.3-11 lists all of the jump, call and return instructions implemented in the Z80 
CPU. A jump is a branch in a program where the program counter is loaded with the 16-bit 
value as specified by one of the three available addressing modes (Immediate Extended, 
Relative or Register Indirect). Notice that the jump group has several different conditions 
that can be specified to be met before the jump will be made. If these conditions are not met, 
the program merely continues with the next sequential instruction. The conditions are all 
dependent on the data in the flag register. (Refer to section 6.0 for details on the flag 
register). The immediate extended addressing is used to jump to any location in the memory. 
This instruction requires three bytes (two to specify the 16-bit address) with the low order 
address byte first followed by the high order address byte. 
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CB 
d 

06 


RflC 


CB 
OF 


C8 
08 


CB 
09 


ca 

OA 


CB 
OB 


CB 
OC 


CB 
OD 


CB 
OE 


DD 
CB 
d 

OE 


FD 
CB 
d 

OE 


'RL' 


CB 
17 


CB 
10 


CB 


CB 
12 


CB 
13 


CB 
14 


CB 
15 


CB 
16 


DO 
CB 
d 

16 


FD 
CB 
d 
16 


RR' 


CB 
IF 


CB 
18 


C8 
19 


CB 
1A 


CB 
18 


CB 
1C 


CB 
ID 


CB 
IE 


DD 
CB 
d 

IE 


FD 
CB 
d 

1E 


'SLA' 


CB 

27 


CB 
20 


CB 

21 


CB 
22 


CB 
23 


CB 
24 


CB 
25 


CB 
26 


OD 
CB 
d 

26 


FD 
CB 
d 

26 


SRA' 


CB 
2F 


CB 
28 


CB 
29 


CB 
2A 


CB 
2B 


CB 
2C 


CB 
20 


CB 
2E 


DD 
CB 

d 

2E 


FD 
CB 
d 

2E 


SRL' 


CB 
3F 


CB 
38 


CB 
39 


CB 
3A 


CB 
3B 


CB 
3C 


CB 
3D 


CB 
3E 


DD 
CB 
d 

3E 


FD 
CB 
d 

3E 


RLD' 
















ED 
6F 






RRD' 
















ED 
67 









A 


RLCA 


07 


RRCA 


OF 


R L A 


17 


RR A 


1F 



Rotate 

Left Circulaf 



Rotate 

Right Circular 



Rotate 
Left 



Rotate 
Right 



> 



Shift 

Left arithmetic 



Shift 

Right Arithmetic 



h3-h 



ACC f_ 



Jt_Lj 



TABLE 5.3-9 



For example an unconditional Jump to memory location 3E32H would 



be: 



Address A 

A+l 
A+2 



C3 



32 



3E 



OP Code 

Low order address 
High order address 



The relative jump instruction uses only two bytes, the second byte is a signed two's com- 
plement displacement from the existing PC. This displacement can be in the range of +129 
to -126 and is measured from the address of the instruction OP code. 



Three types of register indirect jumps are also included. These instructions are implemented 
by loading the register pair HL or one of the index registers IX or IY directly into the PC. 
This capability allows for program jumps to be a function of previous calculations. 

A call is a special form of a jump where the address of the byte following the call instruction 
is pushed onto the stack before the jump is made. A return instruction is the reverse of a call 
because the data on the top of the stack is popped directly into the PC to form a jump 
address. The call and return instructions allow for simple subroutine and interrupt handling. 
Two special return instructions have been included in the Z80 family of components. The 
return from interrupt instruction (RETI) and the return from non-maskable interrupt 
(RETN) are treated in the CPU as an unconditional return identical to the OP code C9H. 
The difference is that (RETI) can be used at the end of an interrupt routine and all Z80 peri- 
pheral chips will recognize the execution of this instruction for proper control of nested 
priority interrupt handling. This instruction coupled with the Z80 peripheral devices imple- 
mentation simplifies the normal return from nested interrupt. Without this feature the 
following software sequence would be necessary to inform the interrupting device that the 
interrupt routine is completed: 
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$53 




Si 


3 




















































3g 


SS 






SS 




2g 


Sg 


Sg 


mg 


5g 




iSS 


3g 


Sg 


mg 


-8 


mS 


3g 




tn O 


$8 


$8 


> 




3S 


2S 


SS 


Sg 


SS 


gg 


gg 


8S 


Sg 


gg 


SS 


3g 


SS 


Sg 


§g 


SS 


2 8 


ss 


SS 


sg 


sg 


sg 


sg 


gg 




Sg 


2?8 


58 


28 


SS 


°g 


sg 


°g 


SS 


»g 


£S 


>g 


sg 


2S 


Sg 


= g 


£g 


^8 


sg 


2g 


Sg 


^8 


sg 


^8 


n 


£8 
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ss 


S8 


SS 




g 


58 


Sg 


£8 


SS 




sg 


SS 


sg 


£8 


Sg 


?g 


sg 


ss 


sg 


SS 


68 


D 


58 


28 


£8 


sg 


SS 


2S 


gg 


gg 


SS 


Sg 


£g 


SS 


gg 


sg 


gg 


sg 


SS 


^S 


sg 


sg 


sg 


sg 


£3 


SS 


m 


SS 


28 


SS 


SS 


Eg 


gg 


Rg 


2g 


Sg 


2g 


og 


£g 




sg 


sg 


2S 


£8 


SS 


08 


28 


sg 


Kg 


oS 


fig 


I 


3S 


Jig 


SS 


sg 


8S 


sg 


sg 


gg 


Sg 


Sg 


gg 


Sg 


§g 


sg 


og 


gg 


sg 


SS 


sg 


sg 


SS 


sg 


dS 


sg 


[- 


SS 


as 


Sg 


58 


SS 


sg 


SS 


SS 


mg 


Sg 


mg 


Sg 


mg 


sg 


mg 


sg 


3 8 


ss 


sg 


sg 


SS 


ss 


mg 


sg 


I 


REG. 
INDIR. 


•naoo 


-no.no 


mQ-OO 


CD (DQ 


s*sg 


s a sg 


m"8g 


s a sg 




00Q.OD 


m a S8 


>Q-OD 


m Sq 


S*8g 


m*8g 


s*Sg 


m^Sg 


s a Sg 


£*gg 


s a sg 


m*sg 




Si a 8g 


s a sg 


1 




-na-o-n 
m cdo 


s a ss 


rss 


si^ss 


s a ss 


S a S3 


S"gS 


8 a 83 


£ a 83 


s*gs 


m^S 


£ a 83 


<oa.o-n 
m ooo 


S-S3 


ffi a 83 




m tt S3 




m^gS 


S-S3 


m*83 


S a S3 


m a g3 


S Q S3 


(P+AI) 



Disable Interrupt — prevent interrupt before 

routine is exited. 

LD A, n — notify peripheral that service 

OUT n, A routine is complete 

Enable Interrupt 

Return 

This seven byte sequence can be replaced with the three byte El RETI instruction sequence 
in the Z80. This is important since interrupt service time often must be minimized. 

To facilitate program loop control the instruction DJNZ e can be used advantageously. 
This two byte, relative jump instruction decrements the B register and the jump occurs if 
the B register has not been decremented to zero. The relative displacement is expressed 
as a signed two's complement number. A simple example of its use might be: 



Address 
N, N+1 

N + 2 to N + 9 

N + 1 0, N + 1 1 
N + 12 



Instruction 
LD B, 7 

(Perform a sequence 
of instructions) 

DJNZ -10 

(Next Instruction) 



Comments 

; set B register to count of 7 

; loop to be performed 7 times 
; to jump from N + 12 to N + 2 



JUMP, CALL AND RETURN GROUP 



CONDITION 





UN- 
COND. 


CARRY 


NON 
CARRY 


ZERO 


NON 
ZERO 


PARITY 
EVEN 


PARITY 
ODD 


SIGN 
NEG 


SIGN 
POS 


REG 
B#0 


JUMP 'JP' 


IMMED. 
EXT. 


nn 


C3 

n 

n 


DA 

n 


02 

n 

n 


CA 

n 

n 


C2 
n 


EA 

n 

n 


E2 

n 

n 


FA 

n 

n 


F2 
n 

n 




JUMP 'JR' 


RELATIVE 


PC+e 


18 
e-2 


38 
e-2 


30 
e-2 


28 
e-2 


20 
e-2 












JUMP 'JP' 


REG. 
INDIR. 


<HL) 


E9 




















JUMP 'JP' 


(IX) 


DD 
E9 




















JUMP 'JP' 


(IY) 


FD 
E9 




















'CALL' 


IMMED. 
EXT. 


nn 


CD 

n 
n 


DC 

n 

n 


04 

n 

n 


CC 

n 

n 


C4 

: ' n 
n 


EC 

n 

n 


..: E4 . 

n 
n 


FC 

: '" n .. 
n 


F4 

n 

n 




DECREMENT B, 
JUMP IF NON 
ZERO 'DJNZ' 


RELATIVE 


PC+e 




















10 

e-2 


RETURN 
'RET' 


REGISTER 
INDIR. 


(SP) 
(SP+1) 


C9 


D8 


DO 


C8 


CO 


E8 


EO 


F8 


FO 




RETURN FROM 
INT 'RETI' 


REG. 
INDIR. 


(SP) 
(SP+1) 


ED 
4D 




















RETURN FROM 
NON MASKABLE 
INT'RETN' 


REG. 
INDIR. 


(SP) 
(SP+1) 


ED 
45 





















TABLE 5.3-11 



NOTE-CERTAIN 
FLAGS HAVE MORE 
THAN ONE PURPOSE. 
REFER TO SECTION 
6.0 FOR DETAILS 
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Table 5.3-12 lists the eight OP codes for the restart instruction. This instruction is a single 
byte call to any of the eight addresses listed. The simple mnemonic for these eight calls is 
also shown. The value of this instruction is that frequently used routines can be called with 
this instruction to minimize memory usage. 



RESTART GROUP 





OP 

CODE 






oooo H 


C7 


'RST 0' 




0008 H 


CF 


'RST 8' 


c 

A 


ooio H 


07 


'RST 16' 


L 








L 
A 


0018 H 


OF 


'RST 24' 


D 








D 
R 
E 


0020 H 


E7 


'RST 32' 


S 








S 


0028 H 


EF 


'RST 40' 




0030 H 


F7 


'RST 48' 




0038 H 


FF 


'RST 56' 



TABLE 5.3-12 



INPUT/OUTPUT 

The Z80 has an extensive set of Input and Output instructions as shown in table 5.3-13 and 
table 5.3-14. The addressing of the input or output device can be either absolute or register 
indirect, using the C register. Notice that in the register indirect addressing mode data can be 
transferred between the I/O devices and any of the internal registers. In addition eight block 
transfer instructions have been implemented. These instructions are similar to the memory 
block transfers except that they use register pair HL for a pointer to the memory source 
(output commands) or destination (input commands) while register B is used as a byte 
counter. Register C holds the address of the port for which the input or output command 
is desired. Since register B is eight bits in length, the I/O block transfer command handles up 
to 256 bytes. 

In the instructions IN A, n and OUT n, A an I/O device address n appears in the lower half 
of the address bus (A0-A7) while the accumulator content is transferred in the upper half 
of the address bus. In all register indirect input output instructions, including block I/O 
transfers the content of register C is transferred to the lower half of the address bus (device 
address) while the content of register B is transferred to the upper half of the address bus. 
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INPUT GROUP 



PORT ADDRESS 









IMMED. 


REG. 
INDIR. 








n 


(C) 






A 


DB 


ED 
78 




R 


B 




ED 
40 


INPUT 'IN' 


E 
G 

A 


C 




ED 
48 


D 
D 
R 
E 


D 




ED 
50 




S 
S 

N 


E 




ED 
58 




G 


H 




ED 
60 






L 




ED 
68 


'INT - INPUT & 
Inc HL, Dec B 








ED 
A2 


'INIR'-INP, Inc HL, 
Dec B, REPEAT IF B¥Q 


REG, 


(HL) 




ED 
B2 


'IND'-INPUT & 
Dec HL, Dec B 


INDIR 






ED 
AA 


'INDR'— INPUT, Dec HL, 
Dec B, REPEAT IF B#0 








ED 
BA 



BLOCK INPUT 
COMMANDS 



TABLE 5.3-13 



CPU CONTROL GROUP 

The final table, table 5.3-15 illustrates the six general purpose CPU control instructions. The 
NOP is a do-nothing instruction. The HALT instruction suspends CPU operation until a 
subsequent interrupt is received, while the Dl and El are used to lock out and enable inter- 
rupts. The three interrupt mode commands set the CPU into any of the three available 
interrupt response modes as follows. If mode zero is set the interrupting device can insert 
any instruction on the data bus and allow the CPU to execute it. Mode 1 is a simplified 
mode where the CPU automatically executes a restart (RST) to location 0038H so that no 
external hardware is required. (The old PC content is pushed onto the stack). Mode 2 is the 
most powerful in that it allows for an indirect call to any location in memory. With this 
mode the CPU forms a 16-bit memory address where the upper 8-bits are the content of 
register I and the lower 8-bits are supplied by the interrupting device. This address points 
to the first of two sequential bytes in a table where the address of the service routine is 
located. The CPU automatically obtains the starting address and performs a CALL to this 
address. 



Address of interrupt 
service routine 



■ Pointer to Interrupt table. Reg. 
I is upper address, 
Peripheral supplies lower address 
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OUTPUT GROUP 



SOURCE 





REGISTER 


REG. 
IND. 


A 


B 


C 


D 


E 


H 


L 


(HL) 


'our 


IMMED. 


n 


D3 
n 
















REG. 
IND. 


(C) 


ED 

79 


ED 
41 


ED 
49 


ED 
51 


ED 
59 


ED 
61 


ED 
69 




'OUTI'- OUTPUT 
Inc HL, Dec b 


REG. 
IND. 


(C) 
















ED 
A3 


'OTIR' - OUTPUT, Inc HL, 
Dec B, REPEAT IF B^O 


REG. 
IND. 


(C) 
















ED 
B3 


'OUTD'- OUTPUT 
Dec HL& B 


REG. 
IND. 


iC) 
















ED 
AB 


'OTDR' - OUTPUT, Dec HL 
& B, REPEAT IF B^O 


REG. 
IND. 


(C) 
















ED 
BB 



— v 
PORT 

DESTINATION 
ADDRESS 



BLOCK 
> OUTPUT 
COMMANDS 



TABLE 5.3-14 



MISCELLANEOUS CPU CONTROL 



'NOP' 


00 


'HALT' 


76 


DISABLE INT '(Dl>* 


F3 


ENABLE INT '{ED- 


FB 


SET INT MODE 
'IMO' 


ED 
46 


SET INT MODE 1 
'IMV 


ED 
56 


SET INT MODE 2 
'IM2' 


ED 
5E 



8080 A MODE 



CALL TO LOCATION 0038 k 



INDIRECT CALL USING REGISTER 
I AND 8 BITS FROM INTERRUPTING 
DEVICE AS A POINTER. 



TABLE 5.3-15 
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6.0 FLAGS 



Each of the two Z80-CPU Flag registers contains six bits of information which are set or 
reset by various CPU operations. Four of these bits are testable; that is, they are used as 
conditions for jump, call or return instructions. For example a jump may be desired only if 
a specific bit in the flag register is set. The four testable flag bits are: 

1) Carry Flag (C) — This flag is the carry from the highest order bit of the accumulator. 
For example, the carry flag will be set during an add instruction where a carry from 
the highest bit of the accumulator is generated. This flag is also set if a borrow is 
generated during a subtraction instruction. The shift and rotate instructions also 
affect this bit. 

2) Zero Flag (Z) — This flag is set if the resu't of the operation loaded a zero into the 
accumulator. Otherwise it is reset. 

3) Sign Flag(S) — This flag is intended to be used with signed numbers and it is set if 
the result of the operation was negative. Since bit 7 (MSB) represents the sign of the 
number (A negative number has a 1 in bit 7), this flag stores the state of bit 7 in the 
accumulator. 

4) Parity /Overflow Flag(P/V) — This dual purpose flag indicates the parity of the result 
in the accumulator when logical operations are performed (such as AND A, B) and it 
represents overflow when signed two's complement arithmetic operations are per- 
formed. The Z80 overflow flag indicates that the two's complement number in the 
accumulator is in error since it has exceeded the maximum possible (+127) or is 
less than the minimum possible (—128) number that can be represented two's 
complement notation. For example consider adding: 



Here the result is incorrect. Overflow has occurred and yet there is no carry to indicate an 
error. For this case the overflow flag would be set. Also consider the addition of two 
negative numbers: 



Notice that the answer is correct but the carry is set so that this flag can not be used as an 
overflow indicator. In this case the overflow would not be set. 

For logical operations (AND, OR, XOR) this flag is set if the parity of the result is even and 
it is reset if it is odd. 

There are also two non-testable bits in the flag register. Both of these are used for BCD 
arithmetic. They are: 



1) Half carry(H) — This is the BCD carry or borrow result from the least significant 
four bits of operation. When using the DAA (Decimal Adjust Instruction) this 
flag is used to correct the result of a previous packed decimal add or subtract. 

2) Add/Subtract Flag (N) — Since the agorithim for correcting BCD operations is 
different for addition or subtraction, this flag is used to specify what type of in- 
struction was executed last so that the DAA operation will be correct for either 
addition or subtraction. 



+120= 0111 1000 
+105 = 0110 1001 

C = 1 1 10 0001 = -95 (wrong) Overflow has occurred; 



-5 = 
-16 = 



C = 1 



1111 1011 
1111 0000 

1110 1011 = -21 correct 



The Flag register can be accessed by the programmer and its format is as follows: 



D7 



D0 



s 1 z 1 x J h I x I p/v 1 nTcI 



X means flag is indeterminate. 

Table 6.0-1 lists how each flag bit is affected by various CPU instructions. In this table 
a ' indicates that the instruction does not change the flag, an 'X' means that the flag goes 
to an indeterminate state, an '0' means that it is reset, a 'V means that it is set and the 
symbol \ indicates that it is set or reset according to the previous discussion. Note that 
any instruction not appearing in this table does not affect any of the flags. 



Table 6.0-1 includes a few special cases that must be described for clarity. Notice that the 
block search instruction sets the Z flag if the last compare operation indicated a match 
between the source and the accumulator data. Also, the parity flag is set if the byte counter 
(register pair BC) is not equal to zero. This same use of the parity flag is made with the 
block move instructions. Another special case is during block input or output instructions, 
here the Z flag is used to indicate the state of register B which is used as a byte counter. 
Notice that when the I/O block transfer is complete, the zero flag will be reset to a zero 
(i.e. B=0) while in the case of a block move command the parity flag is reset when the 
operation is complete. A final case is when the refresh or I register is loaded into the 
accumulator, the interrupt enable flip flop is loaded into the parity flag so that the complete 
state of the CPU can be saved at any time. 



SUMMARY OF FLAG OPERATION 





D7 










P/ 




DO 




Instruction 


c 
o 


y 




n 




V 


M 
111 


c 


Comments 


ADD A,s; ADC A,s 


1 


\ 


x 


i 


X 


V 





t 


8-bit add or add with carry 


SUB,s; SBCA,s; CP,s; NEG 


i 


t 

T 


x 


} 


x 


v 


1 


t 


8-bit subtract subtract with carry, compare and negate accumulator 


AND s 


t 

T 


| 


x 




x 


p 


o 


o 


| Logical operations 


OR s; XOR s 


t 


\ 


x 





x 


p 


o 


o 


IMC s 




) 


x 


\ 


x 


V 


o 


• 


8-bit increment 


DEC s 




i 
t 


x 


t 


x 


v 


1 


• 


8-bit decrement 


ADD DD SS 


• 


• 


x 


x 


x 


• 


o 


t 


16-bit add 


ADC HL, SS 


t 
T 




x 


x 


x 


v 


o 


t 


16-bit add with carry 


SBC HL, SS 


t 
t 




x 


x 


x 


v 


1 


t 


16-bit subtract with carry 


RLA; RLCA; RRA; RRCA 


• 


• 


x 


o 


x 


• 


o 


t 


Rotate accumulator 


RL s- RLC v RR s* RRP s- 


t 
T 


* 

T 


x 


o 


x 


p 


o 


1 


Rotate and shift locations 


SLA s; SRA s; SR L s 




















RLD- RRD 


t 
t 


t 


x 


o 


x 


p 


o 


• 


Rotate digit left and right 


DAA 


t 


( 


x 


i 

T 


x 


p 


• 


t 


Decimal adjust accumulator 


CPL 


• 


• 


x 


1 


x 


• 


1 


• 


Complement accumulator 


SCF 


• 


• 


x 


o 


x 


• 


o 


1 


Set carry 


CCF 


• 


• 


x 


x 


x 


• 


o 


t 

f 


nnmnlpmpnt rarrv 


IN r, (C) 


t 

i 


t 


x 


o 


x 


p 


o 


• 


Input register indirect 


INI- IND- QUIT OUTD 


x 


j 


x 


x 


x 


x 


1 


• 


1 Block input and output 


INI R; IND R; OTIR; OTDR 


X 


1 


X 


X 


X 


X 


1 


• 


f Z = if B otherwise Z - 1 


LDI; LDD 


X 


X 


X 





X 


t 





• 


\ Block transfer instructions 


LDIR' LDDR 


x 


x 


x 


o 


x 


o 


o 


• 


J P/V = 1 if BC =h 0, otherwise P/V = 


CPI; CPIR; CPD; CPDR 


X 


i 


X 


X 


X 


t 


1 


• 


Block search instructions 

Z - 1 if A = ( H L), otherwise Z = 
P/V-1 ifBC^O, otherwise P/V = 


LD A, 1; LD A, R 


t 


\ 


X 





X 


IFF 





• 


The content of the interrupt enable flip-flop (IFF) is copied into 
the P/V flag 


BIT b, s 


X 


\ 


X 


1 


X 


X 





• 


The state of bit b of location s is copied into the Z flag 



The following notation is used in this table: 

SYMBOL OPERATION 

C Carry /I ink flag. C-1 if the operation produced a carry from the MSB of the operand or result. 

Z Zero flag. Z=1 if the result of the operation is zero. 

S Sign flag. S=1 if the MSB of the result is one. 

P/V Parity or overflow flag. Parity (P) and overflow (V) share the same flag. Logical operations affect this flag 

with the parity of the result while arithmetic operations affect this flag with the overflow of the result. 
If P/V holds parity, P/V=1 if the result of the operation is even, P/V=0 if result is odd. If P/V holds over- 
flow, P/V=1 if the result of the operation produced an overflow. 

H Half-carry flag. H~1 if the add or subtract operation produced a carry into or borrow from bit 4 of the 

accumulator. 

N Add/Subtract flag. N-1 if the previous operation was a subtract. 

H and N flags are used in conjunction with the decimal adjust instruction (DAA) to properly correct the 
result into packed BCD format following addition or subtraction using operands with packed BCD format. 
The flag is affected according to the result of the operation. 

• The flag is unchanged by the operation. 

The flag is reset by the operation. 

1 The flag is set by the operation. 
X The flag is a "don't care". 

V P/V flag affected according to the overflow result of the operation. 

P P/V flag affected according to the parity result of the operation, 

r Any one of the CPU registers A, B, C, D, E, H, L. 

s Any 8-bit location for all the addressing modes allowed for the particular instruction. 

ss Any 16-bit location for all the addressing modes allowed for that instruction. 

ii Any one of the two index registers IX or IY. 

R Refresh counter. 

n 8-bit value in range <0, 255> 

nn 16-bit value in range <0, 65535> 

TABLE 6.0-1 
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7.0 SUMMARY OF OP CODES AND EXECUTION TIMES 



The following section gives a summary of the Z80 instruction set. The instructions are 
logically arranged into groups as shown on Tables 7.0-1 through 7.0-11. Each table shows 
the assembly language mnemonic OP code, the actual OP code, the symbolic operation, 
the content of the flag register following the execution of each instruction, the number 
of bytes required for each instruction as well as the number of memory cycles and the 
total number of T states (external clock periods) required for the fetching and execution 
of each instruction. Care has been taken to make each table self-explanatory without 
requiring any cross reference with the text or other tables. 



8-BIT LOAD GROUP 



Mnemonic 



Symbolic 
Operation 



Flags 



P/V 



Op-Code 



76 543 210 



Hex 



No. of 
Bytes 



No. of M 
Cycles 



No. of T 
States 



Comments 



LD r,s 
LD r, n 

LD r, (HL) 
LD r, (IX+d) 



r — s 
r — n 



r-(HL) 
r — (IX+d) 



LD (HL), r (HL)-r • 
LD (IX+d), r (IX+d)-r • 



LD (lY+d), r 

LD (HL), n 
LD (IX+d), n 

LD (lY+d), n 



LD A, (BO 
LD A, (DE) 
LD A, <nn) 



LD (BC), A 
LD (DE), A 
LD (nn), A 



LD A, I 
LD A, R 
LD I, A 
LD R, A 



(HL)-n j» 
<IX+d)-n \ • 



(IY+d)^n 



A-(BC) 
A — (DE) 
A -(nn) 



(BC)-A 
(DE)-A 
(nn) - A 



A*- I 
A ~ R 
I - A 
R-A 



LD r, (lY+d) r -OY+d) • I • \ X 



• ! X 

• ! X 



(JY+d)— r • • ! X 



• ! X 

X 



• ! x 

• I X 



• ! X j • | X 

i I ; 

• i x I • i x 



IFF 
IFF 



• ! • i 11 

; oi 



• 101 

11 

01 

11 

01 



111 

i 00 



r s 
r 110 
n — 
r 110 
011 101 
r 110 
d - 
111 101 
r 110 
d - 
110 r 
011 101 

110 r 
d - 

111 101 
110 r 

d - 
110 110 

n — 

011 101 

110 110 
d - 
n 

111 101 

110 110 
d - 
n -* 
001 010 
011 010 

111 010 
n — 
n — 
000 010 
010010 
110010 
n — 
n 

101 101 

010 111 
101 101 

011 111 
101 101 

000 111 
101 101 

001 111 



DD 



FD 



DD 



FD 



36 

DD 

36 



FD 
36 



OA 
1A 
3A 



2 

| 2 

i 4 



4 
7 

7 

19 



19 



7 

19 



19 

10 
19 

19 



7 
7 

13 



r, s 
000 
001 
010 
011 
100 
101 

111 



02 


1 


2 


7 1 


12 


1 


2 


7 


32 


3 


4 


13 


ED 


2 


2 


9 


57 








ED 


2 


2 


9 


5F 








ED 


2 


2 


9 


47 








ED 


2 


2 


9 


4F 









Reg. 
B 
C 
D 
E 
H 
L 
A 



Notes: r, s means any of the registers A, B, C, D, E, H, L 

IFF the content of the interrupt enable flip-flop (IFF) is copied into the P/V flag 

Flag Notation: •= flag not affected, = flag reset, 1 = flag set, X = flag is unknown, 
t = flag is affected according to the result of the operation. 
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16-BIT LOAD GROUP 



Mnemonic 



Symbolic 
Operation 



Flags 



P/V 



Op-Code 



76 543 210 



Hex 



No. of 
Bytes 



No. of M 
Cycles 



No. of T 
States 



LD dd, nn 
LD IX, nn 

LD IY, nn 



dd *- nn 



IX - nn 



IY - nn 



LD HL, (nn) H - (nn+1) 
j L - (nn) 

LD dd, (nn) j ddn-(nn+1) 
j dd L -(nn) 



LD IX, (nn) 



LD IY, (nn) 



IXH-(nn+1) 
IXL^(nn) 



IY H -(nn+1) 
IY L -{nn) 



LD (nn), HL (nn+1) - H 
' (nn)-L 



LD (nn), dd 



LD (nn), IX 



LD (nn), IY 



(nn+1) - ddn 
(nn)^ dd |_ 



(nn+1) - IXh 
(nnKlX L 



(nn+1) - IYh 
(nn)-IYL 



LD SP, H L 


SP - 


HL 


LD SP, IX 


SP - 


IX 


LD SP, IY 


SP - 


IY 


PUSH qq 


(SP-2) 


- qqL 




(SP-1) 


- qqH 


PUSH IX 


(SP-2) 


^ IX L 




(SP-1) 


-ix H 


PUSH IY 


(SP-2) 


^IY L 




(SP-1) 


-iy h 


POPqq 


qqH- 


(SP+1) 




qql^ 


(SP) 


POP IX 


ix H - 


(SP+1) 




ixl- 


(SP) 


POP IY 


iy h ~ 


(SP+1) 






(SP) 



00 



11 

00 



11 

00 



00 



11 

01 



11 

00 



11 

00 



11 

00 



ddO 001 
n — 
n -* 
011 101 
100 001 
n ~ 
n -~ 
111 101 

100 001 
n - 
n — 

101 010 
n — 
n — 

101 101 
ddl 011 
n — 
n ^ 
011 101 
101 010 
n — 
n - 
111 101 
101 010 
*- n -~ 
n "* 

00 100 010 

n -* 
— n 

11 101 101 

01 ddO 011 

n -~ 
^ n ^ 
011 101 
100 010 



— n 



111 101 
100 010 
n — 



DD 
21 



FD 
21 



2A 



ED 



DD 
2A 



FD 
2A 



22 



ED 



DD 
22 



FD 
22 



11 


111 


001 


F9 


1 


11 


011 


101 


DD 


2 


11 


111 


001 


F9 




11 


111 


101 


FD 


2 


11 


111 


001 


F9 




11 


qqO 


101 




1 


11 


011 


101 


DD 


2 


11 


100 


101 


E5 




11 


111 


101 


FD 


2 


11 


100 


101 


E5 




11 


qqO 


001 




1 


11 


011 


101 


DD 


2 


11 


100 


001 


E1 




11 


111 


101 


FD 


2 


11 


100 


001 


El 





10 
14 

14 

16 
20 

20 
20 

16 
20 

20 

20 

6 

10 
10 
11 
15 
15 
10 
14 
14 



Notes: dd is any of the register pairs BC, DE, HL, SP 
qq is any of the register pairs AF, BC, DE, HL 

(PAIR)h, (PAI R) l refer to high order and low order eight bits of the register pair respectively, 
e.g. BCl= C, AF h = A 

Flag Notation: • = flag not affected, = flag reset, 1 = flag set, X = flag is unknown, 
t flag is affected according to the result of the operation. 
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EXCHANGE GROUP AND BLOCK TRANSFER AND SEARCH GROUP 



Mnemonic 


Symbolic 


Fla 




Op-Code 


No. of 
Bytes 


No. of M 
Cycles 


No. of T 
States 


Comments 


Operation 


s 


2 




H 




P/V 


N 


c 


76 


543 210 


Hex 


EX DE HL 


DE~~HL 






X 




v 

A 








1 1 
1 1 


i m m 1 

I U I U I I 


FR 
CD 


1 


1 


4 




EX AF AF' 


y\F — AF' 






X 




V 
A 








nn 


UU I uuu 


Uo 


1 


1 


4 




EXX 


/BC -~BC \ 






V 
A 




V 
A 










nii nm 

U 1 1 UU I 


uo 


1 


1 


4 


Register bank and 




DE— DE' ) 






























auxiliary register 




\HL~HL'/ 






























bank exchange 


EX (SP) HL 


H — (SP+1 ) 




• 


X 




V 

X 








1 1 
I i 


1 nn ni i 
1 UU U 1 1 


FQ 
to 


1 


5 


19 






L — (SP) 




i 




























FX fSP) IX 


IXu-^SP+1) 


• 


• 


X 


• 


X 


• 


• 




1 1 


011 101 


n n 
UU 


2 


6 


23 






l A l "or; 


















1 1 


100 011 


E3 










FY KPl IV 
CA |ou ( 1 T 


i Yn -~4Qp+1 1 
' ' H wr i I ; 


• 


• 


X 


• 


X 


• 


• 


# 


1 1 


111 101 


FD 


2 


6 


23 






IYi — ^Pi 


















11 


100 011 


E3 
























© 


















Load ( H L) into 


i n i 

LU 1 




• 


• 


X 





X 


* 

J 





• 


1 1 


101 101 


ED 


2 


4 


16 




OE DE+1 


















1 


i nn nnn 
luu UUU 


AO 








(DE), increment the 




H L *■ H L+1 






























pointers and 




BC — BC-1 






























decrement the byte 


































counter (BC) 


LDI R 


(DEMHL) 


• 


• 


X 





X 








• 


11 


101 101 


ED 


2 


5 


21 


If BC* 




nc *. n Cxi 


















10 


1 i n nnn 
11U UUU 


BO 


9 


4 


16 


If BC = 




H L H L+1 


































BC ~~ BC-1 


































R onoat until 
n cptTd 1 U 1 1 IN 


































BC = 














































® 




















LDD 


(DEMHU 


• 


• 


X 





X 


i 

\ 





• 


1 1 


101 101 


ED 


2 


4 


16 






DE DE-1 


















1 


1 n 1 nnn 
1U1 UUU 


A O 

Ao 












H L — H L- 1 


































BC — BC-1 
































LDDR 


{DE)-(HL) 


• 


• 


X 





X 








• 


1 1 


101 101 


c n 

tu 


2 


5 


21 


If BC* 




DE — DE-1 


















i n 
1 u 


111 nnn 
I I I uuu 


DO 


2 


4 


16 


If BC = 




HL — HL-1 


































BC -—BC-1 


































Repgat u ntil 


































r p - n 

DU U 






































(2) 








® 




















ppi 
or i 


A — (HI) 


t 


t 


X 


i 

\ 


X 


i 

\ 


1 




1 1 
1 1 


i m 1 m 
1U1 1U1 


c n 

tu 


2 


4 


16 






H L *- H L+1 
















1 n 
I u 


inn nni 
IUU UUI 


A1 
M I 












BC — BC-1 


































































CPI R 


A - { H L) 


t 


t 


X 


\ 


X 


\ 


1 


• 


1 1 


101 101 


ED 


2 


5 


21 


If BC* and A*{HL 




Mi (-1 1 4-1 
















10 


110 001 


B1 


2 


4 


16 


If BC = or A = (HL) 




B C — 8 C-1 


































Repeat until 


































M in LI U 1 


































d p — n 
oL - U 






































(D 








CD 




















UrU 




t 


t 


X 


t 


X 


! 


1 


• 


1 1 


101 101 


ED 


2 


4 


16 






Ml W 1 -1 
n l n l i 


















10 


101 001 


a n 

Ay 












BC — BC-1 






































® 




























CPD R 


A — (HI) 


♦ 
t 


i 

T 


x 


t 

T 


)( 






• 


1 1 


101 101 


ED 


2 


5 


21 


If BC^Oand A^(HL) 




HL - HL-1 


















10 


111 001 


B9 


2 


4 


16 


If BC = or A = {H L) 




BC - BC-1 


































Repeat until 


































A = ( H L) or 


































BC = 

































Notes: ® P/V flag is if the result of BC-1 = 0, otherwise P/V = 1 
© Z flag is 1 if A = (HL), otherwise Z = 0. 

Flag Notation: • = flag not affected, = flag reset, 1 = flag set, X = flag is unknown, 
t = flag is affected according to the result of the operation. 
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8-BIT ARITHMETIC AND LOGICAL GROUP 



Mnemonic 


Symbolic 
Operation 


Flat 


is 


Op-Code 


Kin n4 
NO. OT 

Bytes 


Kin n4 Ml 

no.ot fvi 
Cycles 


Mn nf T 
VO.OT 1 

States 


Comments 


S 


z 




H 




P/V 


N 


c 


76 543 210 


Hex 


ADD A, r 


A - A + r 


I 




X 


\ 


X 


V 





» 


10 ypOOl r 




1 


1 


4 


r Reg. 


ADD A, n 


A - A + n 


\ 


\ 


x 


t 


x 


V 





) 


11 [oooliio 




2 


2 


7 


UUU b 




















n - 










001 C 
































010 D 


ADD A, <HL) 


A - A+(HL) 


\ 


t 


X 


t 


X 


V 





» 


io [ooolno 




1 


2 


7 


01 1 E 


ADD A, (IX+d) 


A~A+(IX+d) 


\ 




x 


t 


X 


V 





t 


11 011 101 


DD 


3 


5 


19 


1 nn u 
I UU n 






















io [ooolno 










101 L 






















- d * 










111 A 


ADD A, (lY+d) 


A-A+(IY+d) 


\ 


t 


X 


\ 


X 


V 





t 


11 111 101 


FD 


3 


5 


19 
























10 [000] 1 1 
































* d * 












ADC A, s 


A-A+s+CY 


t 


t 


X 


\ 


X 


V 





J 


[oon 










s is any of r, n, 


SUBs 


A-A-s 




t 


X 


i 
j 


x 


V 


1 


t 


[OTol 










(HL), (IX+d), 


SBC A, s 


A-A-s- CY 


t 


1 


X 


t 


X 


V 


1 


t 


lorn 










(IY+d) as shown for 


AND s 


A-A a s 


( 


t 


X 


1 


X 


p 








[TOOl 










ADD instruction. 


OR s 


A ^ A v s 


i 

T 


t 

T 


X 





X 


p 








EH 










The indicated bits 


XORs 


A^A © s 


i 


i 
t 


X 





X 


p 








non 










replace the 10001 in 


CPs 


A-r 


t 


X 


t 


X 


V 


1 


♦ 


nrrn 










the ADD set above. 


INC r 


r *■ r + 1 


t 


i 

f 


X 


\ 


X 


V 





• 


00 r qm 




1 


1 


4 




INC(HL) 


(HLK(HL)+1 


t 


» 


X 


\ 


X 


V 





• 


oo no [Tool 




1 


3 


11 




INC (IX+d) 


(IX+d) * 


I 


t 


X 


t 


X 


V 





• 


11 011 101 


DD 


3 


6 


23 






(IX+d)+1 


















oo nornnr 

* d * 












INC (IY+d) 


(IY+d) - 


t 


♦ 


x 


} 


x 


v 


o 


• 


11 111 101 


FD 


3 


6 


23 






(IY+d}+1 


















00 110 [TOO 












DECs 


s - s - 1 


t 


T 


x 


I 

T 


x 


V 


1 


• 


* d 

[TOT 










s is any of r, (HL), 






























(IX+d), (IY+d) as 
































shown for INC. 
































DEC same format 
































and states as INC. 
































Replace [1001 with 
































(ToT] in OP Code. 



Notes: The V symbol in the P/V flag column indicates that the P/V flag contains the overflow of the result of the 
operation. Similarly the P symbol indicates parity. V = 1 means overflow, V = means not overflow, P = 1 
means parity of the result is even, P = means parity of the result is odd. 

Flag Notation: • = flag not affected, = flag reset, 1 = flag set, X = flag is unknown. 
\ = flag is affected according to the result of the operation. 
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GENERAL PURPOSE ARITHMETIC AND CPU CONTROL GROUPS 



Mnemonic 


Symbolic 
Operation 


FIc 




Op-Code 


No. of 
Bytes 


No. of M 
Cycles 


No. of T 
States 


Comments 


S 


Z 




H 




P/V 


N 


c 


76 


543 210 


Hex 


DAA 


Converts acc, 


t 


t 


X 


t 


X 


p 


• 


t 


00 


100 111 


27 


1 


1 


4 


Decimal adjust 




content into 






























accumulator 




pacKeo dlu 


































following add 


































or subtract 


































with packed 


































dI>u operanas 
































ppi 


A * IT 


• 


• 


X 


1 


X 


• 


1 


• 


00 


101 111 


2F 


1 


1 


4 


Complement 


































accumulator 


































(One's complement} 


IMhu 


A * A + I 


t 


t 


X 


< 


X 


V 


1 




11 


101 101 


ED 


2 


2 


8 


Negate acc, (two's 






















01 


000 100 


44 








complement) 


ppr 


U Y * UY 


• 


• 


X 


X 


X 


• 





* 


00 


111 111 


3F 


1 


1 


4 


Complement carry 


































flag 


ore 


PV 1 

LY * I 


• 


• 


X 





X 


• 





1 


00 


110 111 


37 


1 


1 


4 


Set carry flag 


NOP 


No operation 


• 


• 


X 


• 


X 


• 


• 


• 


00 


000 000 


00 


1 


1 


4 




U A 1 T 

HAL 1 


on ii i i a i 

LrU halted 


• 


• 


X 


• 


X 


• 


• 


• 


01 


110 110 


76 


1 


1 


4 




Dl * 


IFF * 


• 


• 


X 


• 


X 


• 


• 


• 


1 1 


110 011 


F3 


1 


1 


4 




CI * 

El 


IFF * 1 


• 


• 


X 


• 


X 


• 


• 


• 


11 


111 011 


FB 




I 


4 




IM 


Not intorriint 
Ocl 1 1 1 lei 1 U p I 


• 


• 


X 


• 


X 


• 


• 


• 


11 


101 101 


ED 



L 


2 


Q 
O 






mode 


















01 


000 110 


46 










IM 1 


Set interrupt 


• 


• 


X 


• 


X 


• 


• 


• 


11 


101 101 


ED 


2 


2 


8 






mode 1 


















01 


010 110 


56 










IM 2 


Set interrupt 


• 


• 


X 


• 


X 


• 


• 


• 


11 


101 101 


ED 


2 


2 


8 






mode 2 


















01 


011 110 


5E 











Notes: IFF indicates the interrupt enable flip-flop 
CY indicates the carry flip-flop. 

Flag Notation: • = flag not affected, = flag reset 1 = flag set, X = flag is unknown, 
t = flag is affected according to the result of the operation. 

interrupts are not sampled at the end of El or Dl 
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16-BIT ARITHMETIC GROUP 



Mnpmnnir 


Svmhnlic 

iiy muuiiv 

npratinn 
Kj pel a 1,1 u ii 






Op-Code 


No. of 

Dy led 


No of M 

IVU.U ■ IVI 

Cycles 


No.of T 

Ola lea 


Comments 


S 


2 




H 




P/V 


N 


c 


76 543 


210 


Hex 


ADD HL ss 


H L H L+ss 


• 


• 


X 


X 


X 


• 





1 


00 ssl 


001 






Q 

o 


1 1 
1 l 


ss 


Reg. 
































00 


BC 


ADC H I « 


HI — HL-Ks+PY 


t 


» 


X 


X 


X 


V 





t 


11 101 


101 


ED 




A 
** 


I u 


01 


DE 






















01 ssl 


010 










10 


HL 


































11 


SP 


3D Li n L, w 


Ml -cc-PY 
n l n L-ss- u t 


t 




X 


X 


X 


V 


1 


t 


11 101 


101 


ED 


9 
L 


A 


I 3 


























01 ssO 


010 














ADD IV nn 

nUU 'A, \i\J 


1 A 1 A ' \}\J 


• 


• 


X 


X 


X 


• 





t 


11 011 


101 


DD 


9 
L 


A 


1 R 


PP 


Reg. 






















00 ppl 


001 










00 


BC 


































01 


DE 


































10 


IX 


































11 


SP 


ADD IV rr 


1 y — | y + rr 


• 


• 


X 


X 


X 


• 





t 


11 111 


101 


FD 


2 


4 


15 


rr 


Reg. 






















00 rrl 


001 










00 


BC 


































01 


DE 


































10 


IY 


































11 


SP 


INC ss 


- + 1 

5o so T 1 


• 


• 


X 


• 


X 


• 


• 


• 


00 ssO 


011 




] 


) 


6 






INC IX 


IX IX + 1 


• 


• 


X 


• 


X 


• 


• 


• 


11 011 


101 


DD 


2 


2 


10 


























00 100 


011 


23 












INC IV 


IY * |Y + 1 




• 


x 


• 


x 


• 


• 


• 


11 111 


101 


FD 


2 


2 


10 


























00 100 011 


23 












DECss 


ss - ss - 1 




• 


X 


• 


X 


• 


• 


• 


00 ssl 


011 




1 


1 


6 






DEC IX 


IX - IX -1 




• 


X 


• 


X 


• 


• 


• 


11 011 


101 


DD 


2 


2 


10 


























00 101 


011 


2B 












DEC IY 


IY - IY - 1 


• 


• 


X 


• 


X 


• 


• 


• 


11 111 


101 


FD 


2 


2 


10 


























00 101 


011 


2B 













Notes: ss is any of the register pairs BC, DE, HL, SP 
pp is any of the register pairs BC, DE, IX, SP 
rr is any of the register pairs BC, DE, IY, SP. 

Flag Notation: • = flag not affected, = flag reset, 1 = flag set, X = flag is unknown. 
\ = flag is affected according to the result of the operation. 
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ROTATE AND SHIFT GROUP 





Symbolic 


Fla 


gs 


Op-Code 


No. of 


No. of 


No.of 


















p/ 












M 


T 




Mnemonic 


Operation 


s 


z 




H 




v 


N 


c 


76 543 210 


Hex 


Bytes 


Cycles 


States 


Comments 


RLCA 


|CYH— 17- — OH 






Y 
A 


n 
u 


Y 
A 


• 


n 
u 




nn nnn 1 1 1 

UU UUU 1 1 1 


07 


i 
i 


i 
i 


4 


RntatP Ipft rirrtilar 




A 




























accumulator 


R LA 


— |CY j-* — ( / — U r~ 


• 


• 


x 


o 


x 


• 


o 




00 010 111 


17 




1 


4 


Rotate left 




A 




























accumulator 


□ D P A 

n n UA 




• 


• 


x 


o 


x 


• 


o 


t 


00 001 111 


OF 


1 


1 


4 


Rotate right circular 




A 




























accumulator 


RRA 




• 


• 


X 





X 


• 





t 


00 011 111 


1F 


1 


i 
i 


4 


Rntato rinht 
nu Id lb [ iy 1 1 1 




A 




























a r* r 1 1 m 1 1 1 at n r 
dLUU MIUIdLUI 


RLC r 






t 


\ 


X 





X 


p 





\ 


11 001 011 


l 

CB 2 


I 


Q 



Rotate left circular 
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Flag Notation: • = flag not affected, = flag reset, 1 = flag set, X = flag is unknown, 
\ - flag is affected according to the result of the operation. 
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CALL AND RETURN GROUP 



Mnemonic 


Symbolic 
Operation 
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Op-Code 
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n - 
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Bytes 
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If cc is false 
If cc is true 



If cc is false 



If cc is true 
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2 
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C 
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M 
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t 


p 
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011 
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100 


20H 
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30H 
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38H 



1 RETN loads IFF 2 * IFF] 



Flag Notation: • = flag not affected, = flag reset, 1 = flag set, X = flag is unknown, 
\ = flag is affected according to the result of the operation. 
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INPUT AND OUTPUT GROUP 
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Notes: (T) If the result of B - 1 is zero the 2 flag is set, otherwise it is reset. 

Flag Notation: • = flag not affected, = flag reset, 1 = flag set, X = flag is unknown, 
t = flag is affected according to the result of the operation. 
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8.0 INTERRUPT RESPONSE 



The prupose of an interrupt is to allow peripheral devices to suspend CPU operation in an 
orderly manner and force the CPU to start a peripheral service routine. Usually this service 
routine is involved with the exchange of data, or status and control information, between 
the CPU and the peripheral. Once the service routine is completed, the CPU returns to the 
operation from which it was interrupted. 



INTERRUPT ENABLE - DISABLE 

The Z80-CPU has two interrupt inputs, a software maskable interrupt and a non-maskable 
interrupt. The non-maskable interrupt (NMI) can not be disabled by the programmer and 
it will be accepted whenever a peripheral device requests it. This interrupt is generally 
reserved for very important functions that must be ser viced whenever they occur, such as 
an impending power failure. The maskable interrupt (INT) can be selectively enabled or 
disabled by the programmer. This allows the programmer to disable the interrupt during 
periods where his program has timing constraints that do not allow it to be interrupted. 
In the Z80-CPU there is an enable flip flop (called IFF) that is set or reset by the prog- 
rammer using the Enable Interrupt (El) and Disable Interrupt (Dl) instructions. When the 
IFF is reset, an interrupt can not be accepted by the CPU. 

Actually, for purposes that will be subsequently explained, there are two enable flip flops, 
called IFF-i and IFF 2 . 



IFF 



Actually disables interrupts 
from being accepted. 



IFF- 



Temporary storage location 
for IFF-i- 



The state of IFF-| is used to actually inhibit interrupts while IFF2 is used as a temporary 
storage location for I F F 1 . The purpose of storing the IFF-] will be subsequently explained. 

A reset to the CPU will force both IFF<| and IFF2 to the reset state so that interrupts are 
disabled. They can then be enabled by an El instruction at any time by the programmer. 
When an El instruction is executed, any pending interrupt request will not be accepted until 
after the instruction following El has been executed. This single instruction delay is neces- 
sary for cases when the following instruction is a return instruction and interrupts must not 
be allowed until the return has been completed. The El instructions sets both I F F -| and 
IFF2 to the enable state. When an interrupt is accepted by the CPU, both IFF-| and IFF2 
are automatically reset, inhibiting further interrupts until the programmer wishes to issue a 
new El instruction. Note that for all of the previous cases, IFF1 and I FF2 are always equal. 

The purpose of IFF 2 is to save the status of IFF-] when a non-maskable interrupt occurs. 
When a non-maskable interrupt is accepted, IFF-| is reset to prevent further interrupts 
until reenabled by the programmer. Thus, after a non-maskable interrupt has been accepted 
maskable interrupts are disabled but the previous state of IFF-| has been saved so that the 
complete state of the CPU just prior to the non-maskable interrupt can be restored at any 
time. When a Load Register A with Register I (LD A, I) instruction or a Load Register A 
with Register R (LD A, R) instruction is executed, the state of IFF2 is copied into the 
parity flag where it can be tested or stored. 

A second method of restoring the status of IFF-] is thru the execution of a Return From 
Non-Maskable Interrupt (RETN) instruction. Since this instruction indicates that the non 
maskable interrupt service routine is complete, the contents of IFF2 are now copied back 
into I F F -j , so that the status of IFF-] just prior to the acceptance of the non-maskable 
interrupt will be restored automatically. 



Figure 8.0-1 is a summary of the effect of different instructions on the two enable flip flops. 
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FIGURE 8.0-1 



► " indicates no change 



IFF2 "^Parity flag 
IFF 2 ^Parity flag 

IFF 2 ~>IFF 1 



CPU RESPONSE 



Non-Maskable 



A non-maskable interrupt will be accepted at all times by the CPU. When this occurs, the 
CPU ignores the next instruction that it fetches and instead does a restart to location 
0066H. Thus, it behaves exactly as if it had received a restart instruction but, it is to a 
location that is not one of the 8 software restart locations. A restart is merely a call to a 
specific address in page memory. 



Maskable 



The CPU can be programmed to respond to the maskable interrupt in any one of three 
possible modes. 



Mode 



This mode is identical to the 8080A interrupt response mode. With this mode, the interrupt- 
ing device can place any instruction on the data bus and the CPU will execute it. Thus, the 
interrupting device provides the next instruction to be executed instead of the memory. 
Often this will be a restart instruction since the interrupting device only need supply a 
single byte instruction. Alternatively, any other instruction such as a 3 byte call to any lo- 
cation in memory could be executed. 

The number of clock cycles necessary to execute this instruction is 2 more than the normal 
number for the instruction. This occurs since the CPU automatically adds 2 wait states to an 
interrupt response cycle to allow sufficient time to implement an external daisy chain for 
priority control. Section 4.0 illustrates the detailed timing for an interrupt response. After 
the application of RESET the CPU will automatically enter interrupt Mode 0. 



Mode 1 



When this mode has been selected by the programmer, the CPU will respond to an interrupt 
by executing a restart to location 0038 H. Thus the response is identical to that for a non 
maskable interrupt except that the call location is 0038H instead of 0066H. Another 
difference is that the number of cycles required to complete the restart instruction is 2 
more than normal due to the two added wait states. 



Mode 2 



This mode is the most powerful interrupt response mode. With a single 8-bit byte from the 
user an indirect call can be made to any memory location. 

With this mode the programmer maintains a table of 16 bit starting addresses for every in- 
terrupt service routine. This table may be located anywhere in memory. When an interrupt 
is accepted, a 16 bit pointer must be formed to obtain the desired interrupt service routine 
starting address from the table. The upper 8 bits of this pointer is formed from the contents 
of the I register. The I register must have been previously loaded with the desired value by 
the programmer, i.e. LD I, A. Note that a CPU reset clears the I register so that it is ini- 
tialized to zero. The lower eight bits of the pointer must be supplied by the interrupting 
device. Actually, only 7 bits are required from the interrupting device as the least 
bit must be a zero. This is required since the pointer is used to get two adjacent bytes to 
from a complete 16 bit service routine starting address and the addresses must always start 
in even locations. 



Interrupt 

Service 

Routine 

Starting 

Address 

Table 



low order 



high order 



} 



desired starting address 
pointed to by: 



I REG 


7 BITS FROM 





CONTENTS 


PERIPHERAL 



The first byte in the table is the least significant (low order) portion of the address. The 
programmer must obviously fill this table in with the desired addresses before any interrupts 
are to be accepted. 

Note that this table can be changed at any time by the programmer (if it is stored in Read/ 
Write Memory) to allow different peripherals to be serviced by different service routines. 

Once the interrupting device supplies the lower portion of the pointer, the CPU automat - 
cally pushes the program counter onto the stack, obtains the starting address from the table 
and does a jump to this address. This mode of response requires 19 clock periods to com- 
plete (7 to fetch the lower 8 bits from the interrupting device, 6 to save the program 
counter, and 6 to obtain the jump address.) 

Note that the Z80 peripheral devices all include a daisy chain priority interrupt structure 
that automatically supplies the programmed vector to the CPU during interrupt acknow- 
ledge. Refer to the Z80-PIO, Z80-SIO and Z80-CTC manuals for details. 
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INTERRUPT REQUEST/ACKNOWLEDGE CYCLE 



INT 

A0-A15 
Ml 

MREQ 
IQRQ 

DATA BUS 

WAIT 

RD 



Last M Cycle 



of Instruction 



r ~\ /~A 



Last T State 



Ml 



X 



V 



PC 



Daisey Chain 



Priority Frozen 



~r\: 



Vector Placed 



onto Data Bus 



Z80 INTERRUPT ACKNOWLEDGE SUMMARY 



1) PERIPHERAL DEVICE REQUESTS INTERRUPT. Any device requesting and interrupt 
can pull the wired-or line INT low. 

2) CPU ACKNOWLEDGES INTERRUPT. Priority status is frozen when Ml goes low 
during the Interrupt Acknowledge seq uence . Propagation delays down the I E l/l EO 
daisy chain must be settled out when IORQ goes low. If IEI is HIG H, an a ctive Peri- 
pheral Device will place its Interrupt Vecto r on the Data Bus when IORQ goes low. 
That Peripheral then releases its hold on INT allowing interrupts from a higher 
priority device. Lower priority devices are inhibited from placing their Vector on 
the Data Bus or Interrupting because IEO is low on the active device. 

3) INTERRUPT IS CLEARED. An active Peripheral device (IEI=1, IEO=0) monitors 
OP Code fetches for an RETI (ED 4D) instruction which tells the peripheral that its 
Interrupt Service Routine is over. The peripheral device then re-activates its internal 
Interrupt structure as well as raising its I EO line to enable lower priority devices. 
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INTERRELATIONSHIP OF INT, NMI, AND BUSRQ 

The following flow chart details the relationship of three control inputs to the Z80-CPU. Note 
th e fol lowing from the flow chart. 

1. INT and NMI are always acted on at the end of an instruction. 

2. BUSRQ is acted on at the end of a machine cycle. 



3. While the CPU is in the DMA MODE, it will not respond to active inpu ts on IN T or NM I. 

4. T hese three inputs are acted on in the fo llowing order of priority: a) BUSRQ b)NMI c)INT 

Z80-CPU INTERRUPT SEQUENCE 




YES 



SET INT. F/F 



BUSRQ =1 




NON 

MASKABLE 
INTERRUPT 



MASKABLE 
INTERRUPT 
MODE I 
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9.0 HARDWARE IMPLEMENTATION EXAMPLES 

This chapter is intended to serve as a basic introduction to implementing systems with the 
Z80-CPU. 

MINIMUM SYSTEM 

Figure 9.0-1 is a diagram of a very simple Z80 system. Any Z80 system must include the 
following five elements: 

1) Five volt power supply 

2) Oscillator 

3) Memory devices 

4) I/O circuits 

5) CPU 



MINIMUM Z80 COMPUTER SYSTEM 
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V 
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FIGURE 9.0-1 



Since the Z80-CPU only requires a single 5 volt supply, most small systems can be imple- 
mented using only this single supply. 

The oscillator can be very simple since the only requirement is that it be a 5 volt square 
wave. For systems not running at full speed, a simple RC oscillator can be used. When the 
CPU is operated near the highest possible frequency, a crystal oscillator is generally required 
because the system timing will not tolerate the drift or jitter that an RC network will 
generate. A crystal oscillator can be made from inverters and a few discrete components 
or monolithic circuits are widely available. 

The external memory can be any mixture of standard RAM, ROM, or PROM. In this simple 
example we have shown a single 16K bit ROM (2K bytes) being utilized as the entire memory 
system. For this example we have assumed that the Z80 internal register configuration 
contains sufficient Read/Write storage so that external RAM memory is not required. 



Every computer system requires I/O circuits to allow it to interface to the "real world." 
In this simple example it is assumed that the output is an 8 bit control vector and the input 
is an 8 bit status word. The input data could be gated onto the data bus using any standard 
tri-state driver while the output data could be latched with any type of standard TTL latch. 
For this example we have used a Z80-PIO for the I/O circuit. This single circuit attaches to 
the data bus as shown and provides the required 16 bits of TTL compatible I/O. (Refer to 
the Z80-PIO manual for details on the operation of this circuit.) Notice in this example that 
with only three LSI circuits, a simple oscillator and a single 5 volt power supply, a powerful 
computer has been implemented. 

ADDING RAM 

Most computer systems require some amount of external Read/Write memory for data 
storage and to implement a "stack". Figure 9.0-2 illustrates how 256 bytes of static memory 
can be added to the previous example. In this example the memory space is assumed to be 
organized as follows: 



ROM & RAM IMPLEMENTATION EXAMPLE 
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WR 



OD 
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CE 2 



D -D 7 



MREQ 



DATA BUS 



FIGURE 9.0-2 



In this diagram the address space is described in hexidecimal notation. For this example, 
address bit An separates the ROM space from the RAM space so that it can be used for the 
chip select function. For larger amounts of external ROM or RAM, a simple TTL decoder 
will be required to form the chip selects. 

MEMORY SPEED CONTROL 

For m any applications, it may be desirable to use slow memories to reduce costs. The 
WAIT line on the CPU allows the Z80 to operate with any speed memory. By referring 
back to section 4 you will notice that the memory access time requirements are most 
severe during the M1 cycle instruction fetch. All other memory accesses have an additional 
one half of a clock cycle to be completed. For this reason it may be desirable in some 
applications to add one wait state to the M1 cycle so that slower memories can be used. 
Figure 9.0-3 is an example of a simple circuit that will accomplish this task. This circuit can 
be changed to add a single wait state to any memory access as shown in Figure 9.0-4. 
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ADDING ONE WAIT STATE TO AN M1 CYCLE 



WAIT 




-M1- 



T 1 I T 2 I T w | T 3 | T 4 | 



M1 



-\ r 



FIGURE 9.0-3 



ADDING ONE WAIT STATE TO ANY MEMORY CYCLE 



i+5V 



MR EG 



D Q 

7474 
C Q 
R 



H5V 



7400 



WAIT 



D Q 

7474 
C Q 



— \ 



WAIT 



i r 



FIGURE 9.0-4 



INTERFACING DYNAMIC MEMORIES 



This section is intended only to serve as a brief introduction to interfacing dynamic 
memories. Each individual dynamic RAM has varying specifications that will require minor 
modifications to the description given here and no attempt will be made in this document 
to give details for any particular RAM. 

Figure 9.0-5 illustrates the logic necessary to interface 8K bytes of dynamic RAM using 
16-pin 4K dynamic memories. This Figure assumes that the RAM's are the only memory in 
the system so that A-|2 is used to select between the two pages of memory. During refresh 
time, all memories in the system must be read. The CPU provides the proper refresh address 
on lines Aq through As- To add additional memory to the system it is necessary to only 
replace the two gates that operate on A-|2 with a decoder that operates on all required 
address bits. For larger systems, buffering for the address and data bus is also generally 
required. 

An application note entitled "Z80 Interfacing Techniques for Dynamic RAM" is avail- 
able from your MOSTEK representative which describes dynamic RAM design techniques. 



INTERFACING DYNAMIC RAMS 
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4KX8 DYNAMIC 


R/W 


RAM MEMORY 
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RAS 



PAGE 

(0000 to OFFF } 



NO REFRESH ADDRESS MULTIPLEXER REQUIRED 
MREO INITIATES MEMORY CYCLE 
RFSH SELECTS REFRESH CYCLE 



FIGURE 9.0-5 



Z80— CPU DESIGN CONSIDERATIONS: CLOCK CIRCUITRY 



When using the Z80-CPU at less than its rated speed, the Clock Input ($) can be driven by a 
7400 TTL gate with a resistor pull up (typically 330 ohms) to +5 Volts. Because of dynamic 
currents flowing into the Clock Input Pin, the rise time of the Clock Input waveform will 
be typically 60-80 nanoseconds. The resistor will eventually pull the clock input up to Vcc 
but with a slow rise time which will limit the maximum frequency of operation. Figure 
9.0-6 shows a Clock Input driver which has an active pull-up and which will allow maximum 
frequency operation. The circuit is recommended for all but the most cost sensitive Z80 
applications. 



Z80 CPU CLOCK BUFFER CIRCUITRY 



FROM >. 
OSCILLATOR 



33pf 

HI- 



1.2K 
-VSAr- 



220 
-AAAr- 



e 



22 
-WAr- 



-O +5V 



2N3906 or Equivalent 



74S04 



CLOCK 
INPUT 



FIGURE 9.0-6 
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RESET CIRCUITRY 



The Z80-CPU has the characteristic that if the RESET input goes low during T3 of an M1 
cycle that the MREQ signal will go to an indeterminate state for one T-State approximately 
10 T-States later. If there are dynamic memories in the system this action could cause an 
aborted or short access of the dynamic RAM which could cause destruction of data within 
the RAM. If the contents of RAM are of no concern after RESET, then this characteristic 
is no problem as the CPU always resets properly. If RAM contents must be preserved, 
then the falling edge of the RESET input must be synchronized by the falling edge of M1. 

The circuitry of Figure 9.0-7 doe s this s ynchronization a s well a s providing a one-shot 
to limit the duration of the CPU RESET pulse. The CPU RESET signal must be a pulse 
even though the EXTERNAL RESET button is held closed to avoid suspending the CPU 
refresh of dynamic RAM for a time long enough to destroy data in the RAM. 



MANUAL AND POWER— ON RESET CIRCUIT 



+5 



+5 
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EXTERNAL 
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10K 
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TL, 

74132 



74121 



CPU RESET 



7404 



FIGURE 9.0-7 



ADDRESS LATCHING 

In order to guarantee proper operation of the Z80-CPU with dynamic RAMs the upper 
4 bits of the address should be latched as shown in Figure 9.0-8. This action is required 
because the Z80-CP U does not guarantee that the Address Bus will hold valid past the 
rising edge of MREQ on an OP Code Fetch. 

This action does not directly affect dynamic memories because they latch addresses in- 
ternally. The problem comes from the address decoder whic h gener ates RAS. If the address 
lines which drive the d ecoder are allowed to change while MREQ is low, then a "glitch" 
can occur on the RAS line or lines, which may have the effect of destroying one row of 
data within the dynamic RAM. 
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ADDRESS LATCH 
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FIGURE 9.0-8 



RAS TIMING WITH AND WITHOUT ADDRESS LATCH 
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FIGURE 9.0-9 
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10.0 SOFTWARE IMPLEMENTATION EXAMPLES 



10.1 Methods of Software Implementation 

Several different approaches are possible in developing software for the Z80 (Figure 10.1) 
First of all, Assembly Language or a high level language may be used as the source language. 
These languages may then be translated into machine language on a commercial time sharing 
facility using a cross-assembler or cross-compiler or, in the case of assembly language, the 
translation can be accomplished on a Z80 Development System using a resident assembler. 
Finally, the resulting machine code can be debugged either on a time-sharing facility using 
a Z80 simulator or on a Z80 Development System which uses a Z80-CPU directly. 



SOFTWARE GENERATION TECHNIQUES 



SOURCE 
LANGUAGE 



ASSEMBLY 
LANGUAGE 



PL/Z OR OTHER 
HIGH LEVEL 
LANGUAGE 



TRANSLATION 



DEBUGGING 



RESIDENT ASSEMBLER 



CROSS ASSEMBLER 



CROSS COMPILER 



MACHINE 
LANGUAGE 



DEVELOPMENT 
SYSTEM 



SIMULATOR 



FIGURE 10.1 



In selecting a source language, the primary factors to be considered are clarity and ease of 
programming vs. code efficiency. A high level language with its machine independent con- 
straints is typically better for formulating and maintaining algorithms, but the resulting 
machine code is usually somewhat less efficient than what can be written directly in assem- 
bly language. These tradeoffs can often be balanced by combining high level language and 
assembly language routines, identifying those portions of a task which must be optimized 
and writing them as assembly language subroutines. 

Deciding whether to use a resident or cross assembler is a matter of availability and short- 
term vs. long-term expense. While the initial expenditure for a development system is higher 
than that for a time-sharing terminal, the cost of an individual assembly using a resident 
assembler is negligible while the same operation on a time-sharing system is relatively 
expensive and in a short time this cost can equal the total cost of a development system. 

Debugging on a development system vs. a simulator is also a matter of availability and ex- 
pense combined with operational fidelity and flexibility. As with the assembly process, 
debugging is less expensive on a development system than on a simulator available through 
time-sharing. In addition, the fidelity of the operating environment is preserved through 
real-time execution on a Z80-CPU and by connecting the I/O and memory components 
which will actually be used in the production system. The only advantage to the use of a 
simulator is the range of criteria which may be selected for such debugging procedures 
as tracing and setting breakpoints. This flexibility exists because a software simulation can 
achieve any degree of complexity in its interpretation of machine instructions while deve- 
lopment system procedures have hardware limitations such as the capacity of the real-time 
storage module, the number of breakpoint registers and the pin configuration of the CPU. 
Despite such hardware limitations, debugging on a development system is typically more 
productive than on a simulator because of the direct interaction that is possible between 
the programmer and the authentic execution of his program. 



10.2 Software Features Offered by the Z80-CPU 



The Z80 instruction set provides the user with a large and flexible repetoire of operations 
with which to formulate control of the Z80-CPU. 

The primary, auxiliary and index registers can be used to hold the arguments of arithmetic 
and logical operations, or to form memory addresses, or as fast-access storage for frequently 
used data. 

Information can be moved directly from register to register; from memory to memory; 
from memory to registers; or from registers to memory. In addition, register contents and 
register/memory contents can be exchanged without using temporary storage. In particular, 
the contents of primary and auxiliary registers can be completely exchanged by executing 
only two instructions. EX and EXX. This register exchange procedure can be used to 
separate the set of working registers between different logical procedures or to expand the 
set of available registers in a single procedure. 

Storage and retrieval of data between pairs of registers and memory can be controlled on 
a last-in first-out basis through PUSH and POP instructions which utilize a special stack 
pointer register, SP. This stack register is available both to manipulate data and to auto- 
matically store and retrieve addresses for subroutine linkage. When a subroutine is called, 
for example, the address following the CALL instruction is placed on the top of the push- 
down stack pointed to by SP. When a subroutine returns to the calling routine, the address 
on the top of the stack is used to set the program counter for the address of the next 
instruction. The stack pointer is adjusted automatically to reflect the current "top" stack 
position during PUSH, POP, CALL and RET instructions. This stack mechanism allows 
pushdown data stacks and subroutine calls to be nested to any practical depth because the 
stack area can potentially be as large as memory space. 

The sequence of instruction execution can be controlled by six different flags (carry, zero, 
sign, parity /overflow, add-subtract, half-carry) which reflect the results of arithmetic, logical, 
shift and compare instructions. After the execution of an instruction which sets a flag, 
that flag can be used to control a conditional jump or return instruction. These instructions 
provide logical control following the manipulation of single bit, eight-bit byte (or) sixteen- 
bit data quantities. 

A full set of logical operations, including AND, OR, XOR (exclusive -OR), CPL (NOR) and 
NEG (two's complement) are available for Boolean operations between the accumulator and 
1) all other eight-bit registers, 2) memory locations or 3) immediate operands. 

In addition, a full set of arithmetic and logical shifts in both directions are available which 
operate on the contents of all eight-bit primary registers or directly on any memory location. 
The carry flag can be included or simply set by these shift instructions to provide both the 
testing of shift results and to link register/register or register/memory shift operations. 

10.3 Examples of Use of Special Z80 Instructions 

A, Let us assume that a string of data in memory starting at location "DATA" is to be 
moved into another area of memory starting at location "BUFFER" and that the 
string length is 737 bytes. This operation can be accomplished as follows: 



LDIR 



LD 
LD 
LD 



HL, DATA 
DE, BUFFER 
BC, 737 



;START ADDRESS OF DATA STRING 
;START ADDRESS OF TARGET BUFFER 
;LENGTH OF DATA STRING 
;MOVE STRING - TRANSFER MEMORY 
;POINTED TO BY HL INTO MEMORY 
;LOCATION POINTED TO BY DE INCREMENT 
;HL AND DE, DECREMENT BC PROCESS 
;UNTIL BC=0. 



11 bytes are required for this operation and each byte of data is moved in 21 clock cycles. 



B. Let's assume that a string in memory starting at location "DATA" is to be moved 
into another area of memory starting at location "BUFFER" until an ASCII $ char- 
acter (used as string delimiter) is found. Let's also assume that the maximum string 
length is 132 characters. The operation can be performed as follows: 



LD 


HL, DATA 


LD 


DE, BUFFER 


i n 


op 1 09 


LD 


A, '$' 


LOOP: CP 


(HL) 


JR 


Z, END— $ 


LDI 




JP 


PE,LOOP 



END: 



STARTING ADDRESS OF DATA STRING 
STARTING ADDRESS OF TARGET BUFFER 
MAXIMUM STRING LENGTH 
STRING DELIMITER CODE 
COMPARE MEMORY CONTENTS WITH DE- 
LIMITER 

GO TO END IF CHARACTERS EQUAL 
MOVE CHARACTER (HL) TO (DE) 
NCREMENT HL AND DE, DECREMENT BC 
GO TO "LOOP" IF MORE CHARACTERS 
OTHERWISE, FALL THROUGH 
NOTE: P/V FLAG IS USED 
TO INDICATE THAT REGISTER BC WAS 
DECREMENTED TO ZERO. 



19 bytes are required for this operation. 



C. Let us assume that a 16-digit decimal number represented in packed BCD format (two 
BCD digits/byte) has to be shifted as shown in the Figure 10.2 in order to mechanize 
BCD multiplication or division. The operation can be accomplished as follows: 



LD 
LD 
XOR 
ROT AT: RLD 

INC 
DJNZ 



HL, DATA 
B, COUNT 
A 



HL 

ROT AT— $ 



ADDRESS OF FIRST BYTE 

SHIFT COUNT 

CLEAR ACCUMULATOR 

ROTATE LEFT LOW ORDER DIGIT IN ACC 

WITH DIGITS IN (HL) 

ADVANCE MEMORY POINTER 

DECREMENT B AND GO TO ROTAT IF 

B IS NOT ZERO, OTHERWISE FALLTHROUGH 



BCD DATA SHIFTING 

1 1 bytes are required for this operation. 
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1 1 bytes are required for this operation. 



D. Let us assume that one number is to be subtracted from another and a) that they are 
both in packed BCD format, b) that they are of equal but varying length, and c) that 
the result is to be stored in the location of the minuend. The operation can be accomp- 
lished as follows: 



LD HL, ARG1 ;ADDRESS OF MINUEND 

LD DE, ARG2 ;ADDRESS OF SUBTRAHEND 

LD B, LENGTH ;LENGTH OF TWO ARGUMENTS 

AND A ;CLEAR CARRY FLAG 

SUBDEC:LD A, (DE) ;SUBTRAHEND TO ACC 

SBC A, (HL) SUBTRACT (HL) FROM ACC 

DAA ;ADJUST RESULTTO DECIMAL CODED VALUE 

LD (HL), A ;STORE RESULT 

INC HL ;ADVANCE MEMORY POINTERS 

INC DE 

DJNZ SUBDEC-$ DECREMENT B AND GO TO "SUBDEC" IF B 

;NOT ZERO, OTHERWISE FALL THROUGH 



17 bytes are required for this operation. 
10.4 Examples of Programming Tasks 



The following program sorts an array of numbers each in the range <0,255> into 
ascending order using a standard exchange sorting algorithm. 

01/22/76 11:14:37 BUBBLE LISTING 

LOC OBJ CODE STMT SOURCE STATEMENT 



1 
2 
3 
4 
5 
6 
7 
8 
9 

10 
11 
12 
13 
14 
15 
16 
17 
18 
19 
20 
21 
22 



*** STANDARD EXCHANGE (BUBBLE) SORT ROUTINE*** 

AT ENTRY: HL CONTAINS ADDRESS OF DATA 

C CONTAINS NUMBER OF ELEMENTS TO BE SORTED 
(1<C<256) 

AT EXIT: DATA SORTED IN ASCENDING ORDER 
USE OF REGISTERS 
REGISTER CONTENTS 



A 

B 

C 

D 

E 

H 

L 

IX 

IY 



TEMPORARY STORAGE FOR CALCULATIONS 

COUNTER FOR DATA ARRAY 

LENGTH OF DATA ARRAY 

FIRST ELEMENT IN COMPARISON 

SECOND ELEMENT IN COMPARISON 

FLAG TO INDICATE EXCHANGE 

UNUSED 

POINTER INTO DATA ARRAY 
UNUSED 



01/22/76 11:14:37 



BUBBLE LISTING (Cont'd.) 



LOC 


OBJ CODE 


STMT 


SOURCE STATMENT 




0000 


222600 


23 


SORT: 


LD 


(DATA), HL 


;SAVE DATA ADDRESS 


0003 


CB84 


24 


LOOP: 


RES 


FLAG, H 


INITIALIZE EXCHANGE FLAG 


0005 


41 


25 




LD 


B,C 


INITIALIZE LENGTH COUNTER 


0006 


05 


26 




DEC 


B 


;ADJUST FOR TESTING 


0007 


DD2A2600 


27 




LD 


IX, (DATA) 


INITIALIZE ARRAY POINTER 


000B 


DD7E00 


28 


NEXT: 


LD 


A,(IX+0) 


;FIRST ELEMENT IN COMPARISON 


000E 


57 


29 




LD 


D, A 


TEMPORARY STORAGE FOR ELEMENT 


OOOF 


DD5E01 


30 




LD 


E, (IX+1) 


;SECOND ELEMENT IN COMPARISON 


0012 


93 


31 




SUB 


E 


COMPARISON FIRST TO SECOND 


0013 


3008 


32 




JR 


NC f NOEX-$ 


;IF FIRST> SECOND, NO JUMP 


0015 


DD7300 


33 




LD 


(IX), E 


;EXCHANGE ARRAY ELEMENTS 


0018 


DD7201 


34 




LD 


(IX+1), D 




001 B 


CBC4 


35 




SET 


FLAG H 


;RECORD EXCHANGE OCCURRED 


001 D 


DD23 


36 


NOEX: 


INC 


IX 


;POINT TO NEXT DATA ELEMENT 


001 F 


10EA 


37 




DJNZ 


NEXT-$ 


;COUNT NUMBER OF COMPARISONS 














;REPEAT IF MORE DATA PAIRS 


002 1 




oy 




BIT 


FLAG, H 


■HFTFRMIMF IF FXPHANfiF OrPURRFD 


0023 


20DE 


40 




JR 


NZ, LOOP-$ 


CONTINUE IF DATA UNSORTED 


0025 


C9 


41 




RET 




OTHERWISE, EXIT 


0026 




42 
43 


FLAG: 


EQU 





RESIGNATION OF FLAG BIT 


0026 




44 


DATA: 


DEFS 


2 


;STORAGE FOR DATA ADDRESS 






45 




END 







B. The following program multiplies two unsigned 16-bit integers and leaves the result 
in the HL register pair. 

01/22/76 11:32:36 MULTIPLY LISTING 

LOC OBJ CODE STMT SOURCE STATEMENT 



0000 




1 






2 






3 






4 






5 






6 






7 






8 






9 






10 






11 






12 






13 






14 






15 






16 






17 


0000 


0610 


18 


0002 


4A 


19 


0003 


7B 


20 


0004 


EB 


21 


0005 


210000 


22 


0008 


CB39 


23 


000A 


1F 


24 


000B 


3001 


26 



MULT: 



MLOOP: 



UNSIGNED SIXTEEN BIT INTEGER MULTIPLY. 
ON ENTRANCE: MULTIPLIER !N HL 

MULTIPLICAND IN DE. 

ON EXIT: RESULT IN HL. 

REGISTERS USES: 



H HIGH ORDER PARTIAL RESULT 

L LOW ORDER PARTIAL RESULT 

D HIGH ORDER MULTIPLICAND 

E LOW ORDER MULTIPLICAND 

B COUNTER FOR NUMBER OF SHIFTS 

C HIGH ORDER BITS OF MULTIPLIER 

A LOW ORDER BITS OF MULTIPLIER 



LD B, 16; 

LD C,D; 

LD A,E; 

EX DE,HL; 

LD HL,0; 

SRL C; 

RR A; 

JR NC, NOADD-$ 



NUMBER OF BITS-INITIALIZE 
MOVE MULTIPLIER 

MOVE MULTIPLICAND 
CLEAR PARTIAL RESULT 
SHIFT MULTIPLIER RIGHT 
LEAST SIGNIFICANT BIT IS 
IN CARRY. 

IF NO CARRY' SKIP THE ADD. 
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01/22/76 11:32:36 MULTIPLY LISTING (Cont'd.) 



LOC 


OBJ CODE 


STMT 


90MRPF 9TATMFMT 

OW\Jr\V-ft. O 1 r\ 1 IVI L |\J I 




UOUU 


19 


27 


ADD HL, DE; 


ELSE ADD MULTIPLICAND TO 










PARTIAL RESULT. 


nnnc 
UOOb 


r* r> 
CD 


29 


NOADD: EX DE,HL; 


SHIFT MULTIPLICANT LEFT 


000 F 


29 


30 


ADD HL,HL; 


BY MULTIPLYING IT BY TWO. 


0010 


EB 


31 


EX DE,HL; 




0011 


10F5 


32 


DJNZ MLOOP-$; 


REPEAT UNTIL NO MORE BITS. 


0013 


C9 


33 


RET; 








34 


END; 





11.0 ELECTRICAL SPECIFICATIONS 
ABSOLUTE MAXIMUM RATINGS* 

Temperature Under Bias Specified Operating Range 

Storage Temperature -65° C to +150°C 

Voltage on Any Pin with Respect to Ground —0.3V to +7V 

Power Dissipation 1.5W 



D.C. CHARACTERISTICS 

T A = 0°C to 70° C, V<x = 5V ± 5% unless otherwise specified 



SYMBOL 


PARAMETER 


MIN. 


TYP. 


MAX. 


UNIT 


TEST CONDITION 


V|LC 


Clock Input Low Voltage 


-0.3 




0.8 


V 




V IHC 


Clock Input High Voltage 


Vcc-.6 




Vcc+.3 


V 




V|L 


Input Low Voltage 


-0.3 




0.8 


V 




V|H 


Input High Voltage 


2.0 




v C c 


V 




vol 


Output Low Voltage 






0.4 


V 


iOL = 1.8mA 


V H 


Output High Voltage 


2.4 






V 


i h = - 25 °mA 


'cc 


Power Supply Current 






150* 


mA 




1 LI 


Input Leakage Current 






10 


/xA 


V, N = 0to V CC 


"loh 


Tri-State Output Leakage Current in Float 






10 


/xA 


V UT = 2 - 4 t0 V CC 


'lol 


Tri-State Output Leakage Current in Float 






-10 


MA 


V O UT = 0-4V 


'ld 


Data Bus Leakage Current in Input Mode 






+ 10 


/xA 


0<V| N <V CC 



*200mA for -4, -10 or -20 devices 
CAPACITANCE 

T/\ = 25° C, f = 1 MHz unmeasured pins returned to ground 



SYMBOL 


PARAMETER 


MAX. 


UNIT 


C<i> 


Clock Capacitance 


35 


pF 


C|N 


Input Capacitance 


5 


pF 


c OUT 


Output Capacitance 


10 


pF 



*Comment 

Stresses above those listed under "Absolute Maximum Ratings" may 
cause permanent damage to the device. This is a stress rating only and 
functional operation of the device at these or any other condition 
above those indicated in the operational sections of this specification 
is not implied. Exposure to absolute maximum rating conditions for 
extended periods may affect device reliability. 
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MK 3880, MK 3880-10, MK 3880-20 Z80-CPU 
AC CHARACTERISTICS 



T A = 0°C to 70° C, V cc = +5V ± 5%, Unless Otherwise Noted 



SIGNAL 


SYMBOL 


PARAMETER 


MIN. 


MAX. 


UNIT 


TEST CONDITION 




*r f f 


Clock Period 

Clock Pulse Width, Clock High 
Clock Pulse Width, Clock Low 
Clock Rise and Fall Time 


.4 

180 
180 


[12] 

(D) 
2000 

30 


jusec 
nsec 
nsec 
nsec 




A 0-15 


t D(AD) 
^(AD) 

taci 

tea 
*caf 


Muuicas uui)JUL Ucidy 

Delay to Float 

Address Stable Prior to MREQ 

(Memory Cycle) 

Address Stable Prior to IORQ, RD 

orWR {I/O Cycle) 
Address Stable From RD, WR, IORQ or MREQ 
Address Stable From RD or WR 

During Float 


[1] 

[2] 

[3] 
[4] 


110 


nsec 
nsec 
nsec 

nsec 

nsec 
nsec 


C L -50pF 
Except T3-M1 


DO-7 


t D(D) 
t F(D) 

^(D) 

*dci 
*cdf 
*H 


Data Output Delay 

Delay to Float During Write Cycle 

Data Setup Time to Rising Edge of 

Clock During M1 Cycle 
Data Setup Time to Falling Edge at 

Clock During M2 to M5 
Data Stable Prior to WR (Memory 

Cycle) 

Data Stable Prior to WR (I/O Cycle) 
Data Stable From WR 
Input Hold Time 


50 

60 

[5] 

[6] 
[7] 



230 
90 


nsec 
nsec 
nsec 

nsec 

nsec 

nsec 
nsec 
nsec 


C L = 50pF 




tDL^fMR) 


MREO Dplav From FalNna Edap of 
Clock, MREQ Low 




100 


nsec 






t DH4>(MR) 


MREQ Delay From Rising Edge of 
Clock, MREQ High 




100 


nsec 




MREQ 


t DH$(MR) 

VmRL) 
MMRH) 


MREQ Delay From Falling Edge of 

Clock, MREQ High 
Pulse Width, MREQ Low 
Pulse Width, MREQ High 


[8] 
[9] 


100 


nsec 

nsec 
nsec 


C L = 50pF 


iORQ 


t 0L<i>(IR) 
t DL^(IR) 
tDH^IIR) 
t DH5(IR) 


IORQ Delay From Rising Edge of 

Clock, IORQ Low 
IORQ Delay From Falling Edge of 

Clock, IORQ Low 
IORQ Delay From Rising Edge of 

Clock, IORQ High 
IORQ Delay From Falling Edge of 

Clock, IORQ High 




90 
110 
100 
110 


nsec 
nsec 
nsec 
nsec 


C L = 50pF 


RD 


t DL4 ) (RD) 
t DL$(RD) 
t DH<J>(RD) 

1: dh5(bd) 


"RD Delay From Rising Edge of Clock, 
RD Low 

RD _Delay From Falling Edge of Clock, 
RD Low 

RD Delay From Rising Edge of Clock, 
RD High 

RD Delay From Falling Edge of Clock, 
RD High 




100 
130 
100 
110 


nsec 
nsec 
nsec 
nsec 


C L - 50pF 


WR 


t DL ( l>(WR) 
t DL < I > (WR) 


WR Delay From Rising Edge of Clock, 
WR Low 

WR Deiay From Falling Edge of Clock 
WR Low 




80 
90 


nsec 
nsec 


C L = 50pF 




t DH<I ) (WR) 
^(WRL) 


WR Delay From Falling Edge of Clock, 

WR High 
Pulse Width, WR Low 


[10] 


100 


nsec 
nsec 





NOTES: 



A Dat a shou ld be enabled onto the CPU data bus when RD is active. During interrupt acknowledge data should be enabled when M1 
and IORQ are both active. 



B The RESET signal must be active for a minimum of 3 clock cycles, 
cont'd on page 79 
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MK 3880, MK 3880-10, MK 3880-20 Z80-CPU 



SIGNAL 



SYMBOL 



PARAMETER 



MIN. 



MAX. 



UNIT 



TEST CONDITIONS 



M1 



RFSH 



t DL(M1) 
t DH(M1) 



Ml Delay From Rising Edge of Clock 
M1 Low 

M1_Deiay From Rising Edge of Clock 
M1 High 



130 
130 



nsec 
nsec 



C L = 50pF 



t DL(RF) 
t DH(RF) 



RF SH De lay From Rising Edge of Clock, 
RFSH Low 

RF SH De lay From Rising Edge of Clock, 
RFSH High 



180 
150 



nsec 
nsec 



C L = 30pF 



WAIT 



HALT 



INT 



NMI 



BUSRQ 



^(HT) 



Mm 



t w (NML) 



^(BQ) 



WAIT Setup Time to Falling Edge of 
Clock 



70 



nsec 



HALT Delay Time From Falling Edge 
of Clock 



300 



nsec 



C L = 50pF 



INT Setup Time to Rising Edge of Clock 



80 



nsec 



Pulse Width, NM! Low 



80 



BUSRQ Setup Time to Rising Edge of 
Clock 



80 



BUSAK 



t DL(BA) 
t DH(BA) 



BUSAK D elay Fro m Rising Edge of 

Clock , BUSAK Low 
BUSAK Delay Fro m Falling Edge of 

Clock, BUSAK High 



120 
110 



nsec 
nsec 



C L = 50pF 



RESET 



^(RS) 



RESET Setup Time to Rising Edge of 
Clock 



90 



nsec 



r F(C) 



Delay to/from Float (MREQ, IORQ, 
RD and WR) 



100 



nsec 



M1 Stable Prior to IORQ (Interrupt Ack.) 



[11] 



LOAD CIRCUIT FOR OUTPUT 



TEST POINT 



[1] tacm = tw(*H)+t f -75 

[21 t a ci = t c- 80 

[3] t ca = t w (*L) + t f -40 

W t caf = t w (4>L) + t f -60 

t51 t dcm = t c -210 

(6] t dci = t w (*L) + t r -210 

[71 t cdf =t w (<I>L) + t r -80 

[8] t w (MRL) = t c —40 

[9] t w (MRH) = t w (<J>H) + tf - 30 

[10] t w (WR) = t c -40 



FROM OUTPUT 
UNDER TEST 



0) 



250pA 




NOTES (Cont'd.) 

C. Output Delay vs. Load Capacitance 
T A - 70°C V CC = 5V±5% 

Add 10 nsec delay for each 50pF increase in load up 
to a maximum of 200pF for the data bus and 100pF for 

address and control lines. , 

D. Although static by design, testing guarantees t w ($H) of 



[in 



2 t c + t w «E>H) + t f - 80 



200 //sec maximum. 



[12] t c = t w (4>H) + t w («1>L) + t r + tf 
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MK 3880-4 Z80A-CPU 



A. C. CHARACTERISTICS T A = 0°C to 70° C, Vcc = +5V ±5%, Unless Otherwise Noted 



SIGNAL 


SYMBOL 


PARAMETER 


MIN. 


MAX. 


UNIT 


TEST CONDITIONS 




M^H) 


Clock Period 

Clock Pulse Width, Clock High 
Clock Pulse Width, Clock Low 
Clock Rise and Fall Time 


.25 

110 
110 


[12] 

(D) 
2000 
30 


jusec 

nsec 
nsec 
nsec 




A 0-15 


t D(AD) 
^(AD) 
t acm 

^aci 

*ca 
W 


Address Output Delay 
Delay to Float 

Address Stable Prior to MREQ 

(Memory Cycle) 
Address Stable Prior to IORQ, RD 

orWR (I/O Cycle) 
Address Stable From RD, WR, IORQ or MREQ 
Address Stable From RD or WR 

During Float 


[1] 

[2] 

[3] 
[4] 


110 
90 


nsec 
nsec 
nsec 

nsec 

nsec 
nsec 


C L = 50pF 
Except T3.M1 




X D(D) 
X F(D) 
^(D) 

^(D) 

^dcm 

tdci 
*cdf 
*H 


Data Output Delay 

Delay to Float During Write Cycle 

Data Setup Time to Rising Edge of 

Clock During M1 Cycle 
Data Setup Time to Falling Edge at 

Clock During M2 to M5 
Data Stable Prior to WR (Memory 

Cycle) 

Data Stable Prior to WR (I/O Cycle) 
Data Stable From WR 
Input Hold Time 


50 
60 

[5] 

[6] 
[7] 



150 
90 


nsec 
nsec 
nsec 

nsec 

nsec 

nsec 
nsec 
nsec 


C L = 50pF 




tDLifMR) 

t DH4>(M R) 

^H^MR) 

MMRL) 
^(MRH) 


MREQ Delay From Falling Edge of 

Clock, MREQ Low 
MREQ Delay From Rising Edge of 


20 


85 
85 


nsec 
nsec 




MREQ 


Clock, MREQ High 
MREQ Delay From Falling Edge of 

Clock, MREQ High 
Pulse Width, MREQ Low 
Pulse Width, MREQ High 


[8] 
[9] 


85 


nsec 

nsec 
nsec 


C L = 50pF 


IORQ 


t DL < J>(l R) 
t DL < J»(l R) 
t DH4>(i R) 
t DH ( I>(IR) 


IORQ Delay From Rising Edge of 

Clock, IORQ Low 
IORQ Delay From Falling Edge of 

IORQ Delay From Rising Edge of 

Clock, IORQ High 
IORQ Delay From Falling Edge of 

Clock, IORQ High 




75 
85 
85 
85 


nsec 
nsec 
nsec 
nsec 


C L = 50pF 


RD 


t DL$(RD) 
tDL^fRD) 
t DH$(RD) 
t DH$(RD) 


RD Delay From Rising Edge of Clock, 
RD Low 

RD Delay From Falling Edge of Clock, 
RD Low 

RD Delay From Rising Edge of Clock, 
RD High 

RD Delay From Falling Edge of Clock, 
RD High 




85 
95 
85 
85 


nsec 
nsec 
nsec 
nsec 


C L = 50pF 


WR 


^L^WR) 
^L^IWR) 


WR Delay From Rising Edge of Clock, 
WR Low 

WR Delay From Falling Edge of Clock, 
WR Low 




65 
80 


nsec 
nsec 


C[_ = 50pF 




t DH < I ) (WR) 
^(WRL) 


WR Delay From Falling Edge of Clock, 

WR High 
Pulse Width, WR Low 


[10] 


80 


nsec 
nsec 





NOTES: 



A Data should be enabled onto the CPU data bus when RD is active. During interrupt acknowledge data should be enabled when M1 

and IORQ a re both active. 
B The RESET signal must be active for a minimum of 3 clock cycles. 
(Cont'd, on page 81 ) 
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MK 3880-4 Z80A-CPU 



SIGNAL 



SYMBOL 



PARAMETER 



MIN. 



MAX. 



UNIT 



TEST CONDITION 



M1 



t DL(M1) 
t DH(M1) 



M1_Delay From Rising Edge of Clock 
M1 Low 

M1_D_elay From Rising Edge of Clock, 
M1 High 



100 
100 



nsec 
nsec 



C|_= 50pF 



RFSH 



t DL(RF) 
t DH(RF) 



RF SH De lay From Rising Edge of Clock, 
RFSH Low 

RF SH De lay From Rising Edge of Clock 
RFSH High 



130 
120 



nsec 
nsec 



C L = 50pF 



WAIT 



tStWT) 



WAIT Setup Time to Falling Edge of 
Clock 



70 



nsec 



HALT 



^(HT) 



HALT Delay Time From Falling Edge 
of Clock 



300 



nsec 



C L = 50pF 



INT 



h(\T) 



INT Setup Time to Rising Edge of Clock 



80 



nsec 



NMI 



MNML) 



Pulse Width, NMI Low 



80 



nsec 



BUSRQ 



h(BQ) 



BUSRQ Setup Time to Rising Edge of 
Clock 



50 



nsec 



BUSAK 



t DL(BA) 
t DH(BA) 



BUSAK D elay Fro m Rising Edge of 

Clock , BUSAK Low 
BUSAK Delay Fro m Falling Edge of 

Clock, BUSAK High 



100 
100 



nsec 
nsec 



C L = 50pF 



RESET 



MRS) 



RESET Setup Time to Rising Edge of 
Clock 



60 



nsec 



^(C) 



Delax to/From Float (MREQ, IORQ, 
RD and WR) 



80 



nsec 



M1 Stable Prior to IORQ (Interrupt Ack.) 



[11] 



nsec 



LOAD CIRCUIT FOR OUTPUT 



TEST POINT 



Ml t acm = t w ($H) + t f -65 

t2l t aci = t c- 70 

[31 t ca = t w (<I>L) + t r -50 

[4] t caf = t w (4>L) + tr -45 

[51 t dcm = t c -170 

[6] t dci = t w (4>L)+t r -170 

[71 tcdf^w^D+tr-yO 

[8] t w (MRL) = t c -30 



FROM OUTPUT 
UNDER TEST * 



250pA 




R 1 -2.1Kfi 



[9] t w (ivmH)=t w (<I>H) + t f -20 
[10] t w (WR)-t c -30 

tmr = 2t c + t w(* H > +t f- 65 
[12] t c =t w (*H) + tw(*L) + t r + t f 



NOTES (Cont'd.) 

C. Output Delay vs. Load Capacitance 
T A = 70°C V CC = 5V±5% 

Add 10 nsec delay for each 50pF increase in load up 
to a maximum of 200pF for the data bus and 100pF for 
address and control lines 

D. Although static by design, testing guarantees t w ($H) of 
200 jUsec maximum. 
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A.C. TIMING DIAGRAM 

Timing measurements are made at the following voltages, unless otherwise specified: 



"V 



"0' 



CLOCK V cc -.6 .8V 

OUTPUT 2.0 V .8V 

INPUT 2.0 V .8V 

FLOAT AV ±0.5 V 
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12.0 Z80 INSTRUCTION BREAKDOWN BY MACHINE CYCLE 



This section tabulates each Z80 instruction type and breaks each instruction down into its 
machine cycles and corresponding T States. The different standard machine cycles (OP 
Code Fetch, Memory Read, Port Read, etc.) are described in Section 4.0 of this manual. 
This chart will allow the system designer to predict what the Z80 will do on each clock 
cycle during the execution of a given instruction. The instruction types are listed together 
by functions and in the same order as the Tables in Section 7. 

The best way to learn how to use these tables is to look at a few examples. The first 
example is to register exchange instructions (LD r, s) where r,s can be any of the following 
CPU Registers: B,C,D,E,H,L, or A. The instruction breakdown table shows this instruction 
to have one machine cycle (M1) four T-States long (number in parenthesis) which is an OP 
Code Fetch. Referring to Figure 4.0-1 one sees the standard form for an OP Code Fetch and 
the state of the CPU bus during these four T-States. Taking the next instruction shown 
(LD r, n) which loads one of the previous registers with data or immediate value "n" one 
finds the breakdown to be a four T-State OP Code Fetch followed by a three T-State Ope- 
rand Data Read. An Operand Data Read takes the form of the Standard Memory Read 
shown in Figure 4.0-2. 

After these two simple examples, a more complex one is in order. The LD r, (IX+d) is the 
first double byte OP Code shown and executes as follows: First there are two M1 cycles 
(and related memory refreshes) followed by an Operand Data Read of the displacement 
"d". Next M3 consists of a five T-State Internal Operation which is the calculation of the 
Indexed address (IX+d). The last machine cycle (M4) consists of a Memory Read of the 
data continued in address IX+d and the loading of register "r" with that data. 

The LD dd, (nn) instruction loads an internal 16-bit register pair with the contents of the 
memory location specified in the Operand Bytes of the instruction. This instruction is four 
bytes long (two bytes of OP Code + two bytes of Operand Address). As shown, there are 
two M1 cycles to fetch the OP Code and then two Machine Cycles to read the Operand 
Addresses, low order byte first. Machine cycle 4 is a read of memory to obtain the data for 
the low order register (e.g., C of BC, E of DE and L of HL) followed by a read of the data 
for the high order register. 

The first instruction to use the Stack Register is the PUSH qq instruction which executes 
as follows: Machine cycle 1 is extended by one cycle and the Stack Pointer is decremented 
in the extra T-State to point to an empty location on the Stack. Machine cycle 2 is a write 
of the high byte of the referenced register to the address contained in the Stack Pointer. 
The Stack Pointer is again decremented and a write of the low byte of the referenced regis- 
ter is made to the Stack in Machine Cycle 3. Note that the Stack Pointer is left pointing to 
the last data referenced on the Stack. The block transfer instructions such as LDI and LDIR 
are very similar. LDI is 16 T-States long and is composed of a double byte OP Code Fetch 
(two memory refreshes) followed by a memory read and a memory write. The memory 
write is 5 T-States long to allow updating of the block length counter —BC. The repetitive 
form of this instruction (LDIR) has an additional Machine Cycle (M4) of 5 T-States to 
allow decrementing of the Program Counter by two (PC-2) which results in refetching of 
the OP Code (LDIR). Each movement of data by this instruction is 21 T-States long (except 
the last) and the refetching of the OP Codes results in memory refresh occurring as well as 
the sampling of interrupts and BUSRQ. 

The NMI Interrupt sequence is 11 T-States long with the first M1 being a dummy OP 
Code Fetch of 5 T-States long. The Program Counter is not advanced, the OP Code on the 
data bus is ignored and an internal Restart is done to address 66H. The following two 
Machine Cycles are a write of the Program Counter to the Stack. 

The INT Mode is the 8080A mode and requires the user to place an instruction on the 
data bus for the CPU to execute. If a RST instruction is used, the CPU stacks the Program 
Counter and begins execution at the Restart Address. If a CALL instruction is used, the 
CALL Op Code is placed on the data bus during the INTA cycle (M1). M2 and M3 are 



normal Memory Read cycles (not INTA cycles) of the CALL addresses (low byte first). 
Program Counter is stacked in M4 and M5. 

Mode 2 is used by the Z80 System Peripherals and operates as follows: During the INTA 
cycle (M1) a Vector is sent in from the highest priority interrupting device. M2 and M3 
are used to Stack the Program Counter. The Vector (low byte) and an internal Interrupt 
Register (I) from a pointer to a table containing the addresses of Interrupt Service Routines. 
During M4 and M5 the Service Routines address is read from this table into the CPU. 
The next M1 cycle will fetch an OP Code from the address received is M4 and M5. 



LEGEND 

10 - Internal CPU Operation 

MR - Memory Read ODL 

MRH - Memory Read of High Byte PR 

MRL - Memory Read of Low Byte PW 

MW - Memory Write SRH 

MWH - Memory Write of High Byte SRL 

MWL - Memory Write of Low Byte SWH 

OCF - Op Code Fetch SWL 

ODH - Operand Data Read of High Byte ( ) 



Operand Data Read of Low Byte 
Port Read 
Port Write 

Stack Read of High Byte 
Stack Read of Low Byte 
Stack Write of High Byte 
Stack Write of Low Byte 
Number of T-States in that Machine Cycle 



Z80 INSTRUCTION BREAKDOWN BY MACHINE CODE 

MACHINE CYCLE 



INSTRUCTION 
TYPE 


BYTES 


Ml 


m£ 


ivio 




M5 


LD r, s 


1 


OCF (4) 










LD r, n 


2 


OCF (4) 


OD (3) 








LD r, (HL) 
LD (HL), r 


1 


OCF (4) 
OCF (4) 


MR (3) 
MW (3) 








LD r, (IX+d) 
LD (IX+d), r 


3 


OCF (4)/0CF (4) 
OCF (4J/0CF (4) 


0D(3) 
OD (3) 


10 (5) 
10(5) 


MR (3) 
MW (3) 




LD (HL), n 


2 


OCF (4) 


OD (3) 


MW (3) 






BC 

LD A, (DE) 


1 


OCF (4) 


MR (3) 








LD(BC KA 

LD A, (nn) 
LD (nn) , A 




OCF (4) 


MW (3) 








3 


OCF (4) 
OCF (4) 


ODL (3) 
ODL (3) 


ODH (3) 
ODH (3) 


MR (3) 
MW (3) 




i 

R 


2 


OCF (4)/OCF(5) 










R' 














LD dd, nn 


3 


OCF (4) 


ODL (3) 


ODH (3) 






LD IX, nn 


4 


OCF (4)/0CF (4) 


ODL (3) 


ODH (3) 






LD HL, (nn) 
LD (nn), HL 


3 


OCF (4) 
OCF (4) 


ODL (3) 
ODL (3) 


ODH (3) 
ODH (3) 


MRL (3) 
MWL (3) 


MRH (3) 
MWH (3) 


LD (nn), dd 
LD IX, (nn) 

l n (nnl IX 


A 
*t 


OCF (4J/0CF (4) 
OCF (4J/0CF (4) 


ODL (3) 
ODL (3) 

\J\J l_ \ Of 


nnH 
ODH (3) 
ODH (3) 
ODH 


MRI (1\ 
ivi n u. \*jf 

MWL (3) 
MRL (3) 
MWI 11\ 


MRH (3) 

ivi n r i \ \j ) 

MWH (3) 
MRH (3) 
MWH (3) 

ivi vv r i \ o / 


LDSP, HL 


1 


OCF (6) 










LD SP, IX 


2 


OCF (6)/0CF (4) 










PUSH qq 


1 


OCF (5) 

SP-1 


SWH (3) 
► SP-1 


SWL (3) 














► 






PUSH IX 


2 


OCF (4J/0CF (5) 
SP-1 


SWH (3) 

SP-1 


SWL (3) 













*~ 








POP qq 


1 


OCF (4) 

SP+1 


SRH (3) 

SP+1 


SRL (3) 
>. 




















POP IX 


2 


OCF (4)/0CF (4) 
SP+1 


SRH (3) 

SP+1 


SRL (3) 












— ► 


^ 






EX DE, HL 


1 


OCF (4) 










EX AF, AF' 


1 


OCF (4) 
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MACHINE CYCLE 



INSTRUCTION 
TYPE 


BYTES 


Ml 


M2 


M3 


M4 


M5 


EXX 


1 


OCF (4) 










EX (SP), HL 


1 


OCF (4) 


SRL (3) 

SP+1 


SRH (4) 


SWH (3) 

SP-1 


SWL (5) 


EX (SP), IX 


2 


OCF (4)/OCF (4) 


SRL (3) 

SP+1 


SRH (3) 


SWH (3) 

SP-1 


SWL (5) 


LDI 
LDD 
CPI 
CPD 


2 


OCF (4)/OCF (4) 


MR (3) 


MW (5) 






LDIR 
LDDR 
CPIR 
CPDR 


2 


OCF (4J/OCF (4) 


MR (3) 


MW (5) 


IO(5)* 

*only if BC£ 




ALU A, r 
ADD ADC 
SUB SBC 
AND OR 
XOR CP 


1 


OCF (4) 










ALU A, n 


2 


OCF (4) 


OD (3) 








ALU A, (HL) 


1 


OCF (4) 


MR (3) 








ALU A, (IX+d) 


3 


OCF (4J/OCF (4) 


OD (3) 


IO(5) 


MR (3) 




DEC 
INC r 


1 


OCF (4) 










DEC 

INC (HL) 


1 


OCF (4) 


MR (4) 


MW (3) 






DEC 

INC (IX+D) 


2 


OCF (4)/OCF (4) 


OD (3) 


IO (5) 


MR (4) 


MW (3) 


DAA 

CPL 

CCF 

SCF 

NOP 

HALT 

Dl 

El 


1 


OCF (4) 










NEG 
IMO 
IM1 
IM2 


2 


OCF (4)/OCF (4) 
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MACHINE CYCLE 



INSTRUCTION 
TYPE 


BYTES 


Ml 


IVIZ 


MO 

IVIo 




M5 


ADD HL, ss 


1 


OCF (4) 


10 (4) 


10 (3) 






ADC HL, ss 

cop U| cc 

ADD IX, pp 


2 


OCF (4)/OCF (4) 


10 (4) 


10 (3) 






IMP CC 
IIMLr SS 

DEC ss 


i 
i 


OCF (6) 










INC IX 


z. 


OCF f4)/OCF (6) 










RLC A 
RLA 
n n UA 
RRA 


1 


OCF (4) 










RLC r 

RL 

RRC 

RR 

SLA 

CD A 

on A 
SRL 


2 


OCF (4)/OCF (4) 










RLC (HL) 

RL 

RRC 

RR 

SLA 

CPA 
on M 

SRL 


2 


OCF (4)/OCF (4) 


MR (4) 


MW (3) 






RLC (IX+d) 

RL 

RRC 

RR 

SLA 

CD A 

on A 
SRL 


4 


OCF (4)/OCF (4) 


OD (3) 


IO (5) 


MR (4) 


MW (3) 


d i n 

nLU 

RRD 


9 




MR (3) 


IO (4) 


MW (3) 




BIT b, r 

SET 

RES 


2 


OCF (4)/0CF (4) 
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MACHINE CYCLE 



INSTRUCTION 


DVTCC 

BY 1 ho 


m I 


IVIZ 


ItilQ 

IVIo 


IV HA 


IVIO 


TYPE 














BIT b, (HL) 


2 


OCF (4)/OCF (4) 


MR (4) 








SET b, (HL) 


2 


OCF (4)/OCF (4) 


MR (4) 


MW (3) 






RES 














BIT b, (IX+d) 


4 


OCF (4)/OCF (4) 


OD (3) 


IO(5) 


MR (4) 




SET b, (IX+d) 


4 


OCF (4)/OCF (4) 


OD (3) 


10 (5) 


MR (4) 


MW (3) 


RES 














JP nn 


3 


OCF (4) 


ODL (3) 


ODH (3) 






JP cc, nn 














JR e 


2 


OCF (4) 


OD (3) 


10(5) 






JR C,e 


2 


OCF (4) 


OD (3) 


10 (5)* 






JR l\IC,e 








* If condition is met 




JR Z, e 














JR NZ, e 














JP (HL) 


1 


OCF (4) 










JP(IX) 


2 


OCF (4)/OCF (4) 










DJNZ, e 


2 


OCF (5) 


OD (3) 


10 (5)* 

* If 






CALL nn 


3 


OCF (4) 


ODL (3) 


ODH (4) 


SWH (3) 


SWL (3) 


CALL cc, nn 








SP-1 


^ SP-1 


► 


cc true 














CALL cc, nn 


3 


OCF (4) 


ODL (3) 


ODH (3) 






cc false 














R PT 

n t; t 


i 
i 




o n i_ \of 

SP+1 


SRH (3) 














► 






RET CC 


1 


OCF (5) 


SRL (3)* 


SRH (3)* 












* If cc is true 












SP+1 
















► 






RETI 


2 


OCF (4J/OCF (4) 


SRL (3) 


SRH (3) 






RETN 






SP+1 








RST p 


1 


OCr (5) 
SP-1 


SWH (3) 
SP-1 




SWL (3) 
► 
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MACHINE CYCLE 



INSTRUCTION 
TYPE 



BYTES 



Ml 



M2 



M3 



M4 



M5 



IN A, (n) 

IN r, (c) 

INI 
IND 

INIR 
INDR 

OUT (n) , A 

OUT (C), r 

OUTI 
OUTD 

OTIR 
OTDR 

INTERRUPTS 
NMI 

INT 

MODE 



MODE 1 



MODE 2 



2 
2 
2 



2 
2 
2 



OCF (4) 

OCF (4J/OCF (4) 
OCF (4J/OCF (5) 

OCF (4)/OCF (5) 

OCF (4) 

OCF (4)/OCF (4) 
OCF (4)/OCF (5) 

OCF (4J/OCF (5) 



OD (3) 
PR (4) 
PR (4) 

PR (4) 

OD (3) 
PW (4) 
MR (3) 

MR (3) 



OCF (5) * 
SP-1 



SWH (3) 
SP-1 



INTA (6) 



ODL (3) 



(CALL INSERTED) 



INTA (6) 
(RST INSERTED) 
SP-1 



INTA (7) 
(RST 38H 
INTERNAL) 
SP-1 



INTA (7) 
(VECTOR 
SUPPLIED) 
SP-1 



SWH (3) 
SP-1 



SWH (3) 



SP-1 



SWH (3) 



SP-1 



PR (4) 

MW (3) 
MW(3) 
PW (4) 

PW (4) 
PW (4) 



SWL (3) 
► 



ODH (4) 
SP-1 



SWL (3) 



SWL (3) 



SWL (3) 



IO(5) 



IO(5) 



*Op Code Ignored 



SWH (3) 
SP-1 



MRL (3) 



SWL (3) 



MRH (3) 
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13.0 PACKAGE DESCRIPTION AND ORDERING INFORMATION 



PACKAGE DESCRIPTION - 40 Pin Dual-ln-Line Ceramic Package 



2.000 t 020- 



032R. 
MAX 



/ 



SYMBOLIZATION AREA FOR 
IDENTIFICATION OF PIN 1 



.080 
.040 
.040 



.506 . 578 .600 
SQUARE *OI0 -OlO 



.625 
+ .025 



| .0015 1 



.010 
1.001 



.05TYP— » 



19 EQUAL SPACES 100=1.900 
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025 TYP 
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PACKAGE DESCRIPTION - 40-Pin Dual-ln-Line Plastic Package 



+ 010 
~ 2 050 ^010" 



nnnnnnnnnnnnnnnnnnn 



i 



C 



.180+ .005 



I — I I — 1 I — I I — 1 I — I ! — I I — I I — I I — 1 1 — [ I — I I I I — I I 1 1 II I I II I I II | 
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ORDERING INFORMATION 



PART NO. 


PACKAGE TYPE 


MAX CLOCK FREQUENCY 


TEMPERATURE RANGE 


MK3880N Z80-CPU 


Plastic 


2.5 MHz 




MK3880P Z80-CPU 


Ceramic 


2.5 MHz 


0° to + 70° C 


MK3880N-4 Z80-CPU 


Plastic 


4.0 MHz 




MK3880P-4 Z80A-CPU 


Ceramic 


4.0 MHz 




MK3880P-10Z80-CPU 


Ceramic 


2.5 MHz 


-40°Cto +85°C 


MK3880P-20 Z80-CPU 


Ceramic 


2.5 MHz 


-55° C to +125° C 
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ERATTA: Z80 ASSEMBLY LANGUAGE PROGRAMMING MANUAL 



On pages 93 and 97 , change as follows 

FROM: For BOO and A=(HL) 
TO: For BC^O and A^(HL) 



On pages 85 and 89, changes as follows: 



FROM: For BC=0 

M cycles: 5 

TO: For BC^O 

M cycles: 5 



On pages 258, 262, 269, 273, change as follows: 

FROM: If B=0 

M cycles: 5 
TO: If B^O 

M cycles: 5 
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